微信原生小程序+云开发。我这里主要使用了云开发能力中的小程序端SDK,说白了就是在javascript中就能直接操作数据库。
基于云开发的答题活动小程序v2.0的源码地址,以及手把手教你搭建答题活动小程序v1.0系列文章目录,均在【基于云开发的答题活动小程序v2.0,终于赶在11月最后一天完成了】这篇文章的底部。
本篇主要结合实际的场景,譬如在答题活动小程序中,如何利用路由传参的方式,进而提高页面或者组件的可复用性。
一图胜过千言万语,结合答题小程序的应用场景,让我们率先来看看整个演化过程。
(1)答题页
在答题页面中,当作答完毕,提交并生成答题记录后,后端会返回该条记录的id,这时就可以执行跳转到答题结果页面,获取数据后显示得分。
test.js
activityRecord.add({ data: { ...examResult, createDate: db.serverDate() } }).then(res => { // 跳转到答题结果页,查看成绩 wx.reLaunch({ url: '../result/result?id=' + res._id }); })
(2)答题结果页
进入答题结果页面,页面加载时触发onLoad,可以在 onl oad 的参数中获取打开当前页面路径中的参数。然后发送请求,入参为该id,即可获取该数据。
result.js
//生命周期函数--监听页面加载 onLoad(options) { // 查看答题成绩 this.getExamResult(options.id); }, getExamResult(id){ activityRecord .doc(id) .get() .then(res => { let examResult = res.data; }) }
(3)答题记录页
在答题记录页面中,需要查看历史成绩时,当点击列表里面的某一条记录,这时会携带该记录的id作为参数值,跳转到答题结果页面,获取数据后显示得分。
history.wxml
<view class="cu-item arrow" wx:for="{{historyList}}" wx:key="index" bindtap="goToResult" data-id="{{item._id}}"> </view>
history.js
goToResult(event){ const { id } = event.currentTarget.dataset; // 跳转到答题结果页,查看成绩 wx.navigateTo({ url: '../result/result?id=' + id }) }
【延伸一下】事件的使用方式:
在组件中绑定一个事件处理函数。
在相应的Page定义中写上相应的事件处理函数,参数是event。
dataset为当前组件上由data-开头的自定义属性组成的集合。
我将答题结果页设计成了一个可复用的组件,只要通过参数,就能获取到答题成绩。无论是从答题页过来,还是从答题记录页过来,所查询的答题结果均可在这个页面上展示,就无需重新再多做一个页面了。
将整个答题小程序划分为若干紧密关联的页面,以及高内聚低耦合的组件,理清职责、交互与边界。划分的基本原则是“识别、分离和组合关注点”。
可见,组件化是可灵活组合和可定制的前提,是构建软件应用的核心思想。