用户
 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
  • TA的每日心情
    无聊
    2017-8-15 16:38
  • 签到天数: 42 天

    [LV.5]常住居民I

    859

    主题

    2046

    帖子

    3万

    金钱

    管理员

    论坛管理员

    Rank: 9Rank: 9Rank: 9

    积分
    0

    突出贡献优秀版主荣誉管理论坛元老

    QQ
    2016-12-6 10:59:38 zhichi_admin 管理员 楼主 133785
    零基础学开发,她做了款「仿知乎」小程序 | 实战教程有多少人是零基础,又想学小程序开发呢?今天,给大家分享一个励志案例:一个读大气科学、自学前端开发的妹子,因为喜欢逛知乎,自己做出了一款「仿知乎」小程序。

    希望她的开发经验,能帮大家轻松愉悦地迈出小程序开发的第一步。

    作者 | Rebecca Han
    WEB 前端/不靠谱天气预报员/想做代码小仙女
    微信小程序开始内测到现在,我终于把自己的微信小程序 demo 完成了。真的是磨叽完的,连我自己都佩服自己的拖延症了(懒癌少女已弃疗 ヾ(´A`)ノ゚) 总之,算是基本完成了(明明有很多组件啊、API 啊根本都没用好嘛 →_→)以及从来不写 blog 的我也出来码字啦 (ノ◕ヮ◕)ノ:・゚✧之前有很长一段时间,我算是知乎重度依赖。所以,这次 demo 的模仿对象选择的是知乎(但是写到一半发现我这个决定坑了,这是后话)。Demo 的界面设计以及交互设计,均来自于知乎 Android 版本。
    • 工具:使用的是微信 web 开发者工具,这个工具已经全面对非邀请内测用户开放,且在持续更新中(我码代码的过程中就更新了两版,所以开发时 IDE 版本不唯一)。其实,忍受了半个小时微信的开发者工具之后,我就改在 Webstorm 中编辑了,微信工具成了运行预览的工具。不过听说 IDE 中预览的效果,也不能保证与真机一样哦~
    • 设计和功能:参照的是知乎安卓版本非常之简易版,为了防止版权问题,Demo 中的 fake 数据使用的是我自己的回答。

    文件构建1. 基础文件app.json
    app.json 文件中是对整个小程序的全局配置,主要用到的字段有pageswindowtabBarnetworkTimeout
    • pages 字段:所有小程序的页面都要在该字段中注册,该字段数组中的第一个 page 默认为小程序首页(设置 tab 除外),没有在 pages 字段注册过的页面貌似不能够进行有效的编译(之前版本的编辑器没有这个限制,只是会影响配置文件等的生效,编辑器更新后会报未注册的错误)。
    • window 字段:大多是关于小程序顶部 navigationbar 的一些设置。
    • tabBar 字段:如果你需要首页底部带 tabbar 的样式,那么就在 tabBar 字段中设置每个 tab 对应的页面,按顺序对应左至右,包括路径、tab 文字、tab 图标和选中状态图标。
    • networkTimeout:设置网络超时时间。
    • debug:开启 debug 模式。

    app.wxss 文件中为全局样式,也就是说这个文件中的样式在所有的 pages 中均可使用。若其他页面文件的 WXSS 中定义了与该样式文件中相同的属性,则该文件中的样式被覆盖,规则与 CSS 优先规则大致相通。app.js 用于调用 login 接口、回调、周期函数、本地存储等等逻辑代码。2. 页面文件页面文件由四部分组成。例如,我们有一个首页叫做 index,则需要在 pages 文件夹下创建文件名相同的三个必要文件:
    • index.wxml
    • index.wxss
    • index.js

    另外 index.json 文件为可选,功能与 app.json 相同,为该页面的配置文件,但定义功能有限。3. UI跟平时开发一样,最开始当然是码 UI。除了需要依照微信的一些新的标签和样式规则,其他与平时码 UI 并没有太大的不同。而且需要强调的是,flex 布局在微信小程序中 hin~~~~好用不过,同时作为女生和程序员,不挑刺可就不是我了,所以下面列举了一些我遇上的坑,其中有些也许不正确(多多包涵啦(//∇//)\),有些也许已在 IDE 更新中修正:
    • 有一些 CSS 样式在微信 IDE 中不支持,例如 font-weight、letter-spacing(以及调整字间距的样式)等;
    • <text/> 不支持嵌套,<text/> 两层嵌套的结构下,内层中的内容会连续显示两次(在 IDE 后续更新中已修正);
    • 若 <view/> 与 <text/> 同级,则在实际使用中,<view /> 会遮住 <text />。为了防止内容相叠,必须使用 <view/> 相并列。所以并不像某些地方说的,可以完全地把 <view/> 当做 <div> 去使用!
    • 元素之前有垂直相邻 margin 的时候,在微信小程序中会 double 显示,即两个元素的 margin 均摊开,不遵循 margin 折叠规则;
    • 标签 hidden 属性无效(v0.10.101400 中已修正);
    • 部分情况下,平级元素标签优先级会出现问题。比如, 平级标签 A 与 B,当 B 通过某些调整向 A 元素位置相叠的时候,微信 IDE 解析出的效果是 A 的内容和背景色会覆盖 B 元素与之重叠的部分(普通浏览器解析应该是 B 覆盖 A);
    • 如果用模板+列表渲染的方式来渲染数据的话,在模板中使用列表渲染的 {{item}} 是无效的,无法被正确识别。所以,列表渲染的时候,要把复用的部分写在列表渲染的代码块内(属于数据渲染部分,后面会提到)。

    在后来,微信 IDE 的迭代中已经将上面清单中的一些问题修正了,所以这份清单有可能是过时的。大家也可以根据实际情况,自行尝试。

    接下来,我将对于一些 demo 中写到用到的部分进行说明。

    开始实战开发1. 列表式的数据渲染类似于「首页」以及「发现页」这种标准列表式的数据展现方式,微信提供了很好的方案:列表渲染。
    可以直观地看出,就是 for 循环用重复的结构渲染一组数据:
    • for="{{}}" 中的内容是想要循环的一组数据,最外层为数组结构
    • for-item 指定数组中当前元素的变量名
    • for-index 指定数组中当前元素下标变量名

    同样也使用了 for 渲染的,还有顶部的发现页和通知页等顶部的自定义 tabbar。2. 顶部 Tabbar 实现微信只提供了底部 tabbar,所以顶部的要自己写喽~顶部 tabbar 的实现在于 for 列表渲染以及 JS 配合。实例 WXML 代码:

    JS 代码:


    由于微信不支持使用 DOM 访问对象,也就是不支持 domwindow 对象,所以 tabbar 的实现依赖于微信提供的视图层的展示逻辑,以及视图与数据之间的绑定机制。绑定点击事件,通过改变一个 data- 属性的值,来控制元素的类的改变(从而改变样式等)。3. 轮播图以下是实现的 WXML 代码:

    JS 代码:


    轮播图的实现使用的是微信提供的 swiper 组件,该组件贴心的提供了各种属性选择,常用的包括 autoplay、interval 时间 durationswiper-item 中包含的是所有轮播的图片,为了方便修改图片数据,同样采用 for 渲染绑定 data 的方式。4. 下拉刷新,上拉加载,以及数据请求刷新及继续加载的动作,依靠的是 scroll-view 标签,及配套的 upperlower 事件。标签的属性提供了 bindscrolltoupperbindscrolltolower 来绑定滚动到顶部及底部所触发的事件,同时 upper-thresholdlower-threshold 能够调整触发时距边界的距离。除上述之外,小程序的 API 还提供横向滚动、滚动触发事件、设置滚动条位置等接口
    滚动至顶或至底时,触发的加载数据的事件,本应该调用微信提供的网络请求 API 来获取数据。但是比较坑的是,我在选择写仿知乎 demo 的时候没有注意到知乎不提供开放 API,而微信的 API 不支持直接对 JSON 文件进行本地请求。无奈之下,选择在 JS 文件中伪造一段数据,用 module.exports 抛出,来 fake 数据请求:
    由于是 fake 的数据,所以这个 demo 并没有做真实的带参跳转,查询等功能。加载数据的同时,还使用到了微信提供的加载动画函数 wx.showNavigationBarLoading();5. 其他
    • 为了实现点击跳转页面,使用了 wx.navigateTo 进行页面跳转以及点击事件绑定;
    • 部分常用组件的模块化;
    • input、image 组件等的使用。

    6. 后续其实还有大量的组件和 API 还没有用过,这个 demo 也许后续还会有更新呦,这取决于懒癌少女的病情严重程度了。一点感受其实作为一个小前端,由于工作中的原因,使用 MVVM 其实是非常少的。不过,写了这个微信小程序 demo 之后,更加把这方面的思维理顺了。当然,写完之后回头看,还是有超多的不足,明明好些地方能再换一种写法的。这毕竟是我第一次尝试用新鲜热乎的东西写小 demo,也是第一次尝试写教程……或者算是记录?whatever~~Anyway~ 希望除了写代码之外,还能在码文字的道路上也多走走吧,毕竟我是要做代码小仙女的人呀\(≧∀≦)ゞ

    游客,如果您要查看本帖隐藏内容请回复


    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?立即注册

    x
    使用道具 举报 回复
    好牛逼!
    使用道具 举报 回复
    看看美女的东西
    啥也不说了,感谢楼主分享哇!
    啥也不说了,感谢楼主分享哇!
    啥也不说了,感谢楼主分享哇!
    啥也不说了,感谢楼主分享哇!
    厉害了小姐姐
    厉害了小哥哥
    入门不错
    使用道具 举报 回复
    12下一页
    发新帖
    *滑动验证:
    您需要登录后才可以回帖 登录 | 立即注册
    咫尺论坛|小程序开发社区
    X