微信小程序怎么实现数据双向绑定

阅读 12259  ·  发布日期 2020-08-24 17:26  ·  温州雄霸网络科技有限公司|建站|APP小程序制作|做网站SEO推广优化
【摘要】 在原生小程序开发中,数据流是单向的,无法双向绑定,但是要实现双向绑定的功能还是蛮简单的!下文要讲的是小程序框架 minapp 中实现双向绑定的原理,在 minapp 中,你只需要在 wxml 模板中给组件的属性名后加上 .sync 就可以实现双向绑定。下面为了解释其原理,过程可能会说的稍微复杂些,但其实 minapp ... 【温州小程序开发,温州微信公众号,平阳做网站,平阳网站建设公司,平阳小程序商城制作,昆阳万全做网站,鳌江水头小程序,萧江腾蛟微信公众号,山门顺溪南雁海西南麂凤卧麻步怀溪网络网店服务,政采云网店管理服务】...

微信小程序怎么实现数据双向绑定

在原生小程序开发中,数据流是单向的,无法双向绑定,但是要实现双向绑定的功能还是蛮简单的!下文要讲的是小程序框架 minapp 中实现双向绑定的原理,在 minapp 中,你只需要在 wxml 模板中给组件的属性名后加上 .sync 就可以实现双向绑定。
下面为了解释其原理,过程可能会说的稍微复杂些,但其实 minapp 框架已经处理了那些繁杂的细节!首先,要使数据双向绑定,应该避免过多的数据源。
在数据从上到下自然流动的情况下,如果每个组件中都维护它们自己的数据,而又要保持它们数据值的一致,这虽然可以做到,但实现过程并不会简单。
但是也没必要说为了有一个统一的数据源就使用 mobx 或 redux 来全局管理数据,这就有点杀鸡用牛刀的感觉了。
由于双向绑定只存在于父子组件之间,而数据又是从父到子传递的,所以可以优先使用父组件中的数据为数据源,子组件每次更新数据并不更新它自己内部的数据,而是通过事件机制触发父组件更新它的数据,而父组件更新数据后又会将更新的数据自然地传给子组件,由此达到数据的双向流动!并不是所有数据都需要双向绑定,也并不是所有数据都是对外的,子组件还可以有它自己的一个内部数据。
所以这就涉及到我们要说的第二个问题:
区分哪些数据需要双向绑定,哪些数据又需要子组件自己维护。
用过 vue 的应该都知道,在 vue 中要实现双向绑定,需要在模板中做特殊处理。
比如要将父组件的 parentAttr 双向绑定到子组件的 childAttr 上,需要在父组件的模板中这样写:
但是小程序并没有这样的简单的语法,小程序的 wxml 语言的属性名中甚至都不允许出现 " . " 这样的字符。
回到我们的问题上来,子组件需要知道哪些属性需要双向绑定,哪些属性需要自己维护,给模板加个字段(syncAttrMap)专门来告诉子组件需要双向绑定的数据集合不就行了么。
如,可以将上面的示例写成微信小程序支持的写法:
接着,就需要处理子组件数据更新的问题了,在子组件中有两部分数据,一部分是内部数据,另一部分是父组件中的数据,子组件可以通过读取属性 syncAttrMap 来得到哪些数据是内部的数据,哪些数据是父组件的数据,并且可以知道对应的父组件中的数据的键名是什么。
由于原生的组件方法 setData 不会管你是内部数据,还是父组件中的数据,只要你调用它去更新数据,它只会更新内部的数据。
所以需要另外实现一个新的方法,来自动判断数据源,如果是内部数据,则直接调用 setData ;如果是双向绑定中的父组件数据,则可以触发一个事件去通知父组件去更新对应的值。
所以根据上面的描述,父组件需要有个监听函数,子组件需要有个智能的 setData 函数。
不防将父组件的监听函数命名为 onSyncAttrUpdate,将子组件的智能 setData 函数命名为 setDataSmart,则可以有如下代码:
// 父组件Component({
methods: {
onSyncAttrUpdate(e) {
this.setData(e.detail) // 子组件传来的需要更新的数据 }
}
}
)// 子组件Component({
properties: {
childAttr: String, syncAttrMap: String }
, methods: {
// 子组件更新数据时,只要调用此方法即可,而不是 `setData` setDataSmart(data) {
// splitDataBySyncAttrMap 函数的实现过程就不说了,只是将对象拆分,大家应该都能实现 let {
parentData, innerData}
= splitDataBySyncAttrMap(data, this.data.syncAttrMap) // 内部数据使用 setData 更新 if (Object.keys(innerData).length) {
this.setData(innerData) // setData 中还支持 callback 的回调,为了简化代码,这里不讨论 }
// 双向绑定的父组件数据触发事件让父组件自己去更新 if (Object.keys(parentData).length) {
this.triggerEvent('
syncAttrUpdate'
, parentData) }
}
}
}
)到此,一个简单的双向绑定功能就完成了。
但是由于子组件也有可能包含其它组件,也就是说子组件也可以是父组件,而父组件同样也可以是子组件。
所以上面的 onSyncAttrUpdate setDataSmart 函数需要在每个组件中都实现,所以不防定义一个公共对象 BaseComponent 来实现上面的所有功能,如:
// BaseComponentconst BaseComponent = {
properties: {
syncAttrMap: String }
, methods: {
setDataSmart() {
// ... }
, onSyncAttrUpdate() {
// ... }
}
}
然后将 BaseComponent minin 到每个组件的对象上去就可以了;另外小程序中还有一个特殊的组件:
Page,虽然 Page 和 Component 结构是两样的,但它也应该算是一个组件,不过它一定是父组件,不可能是别的组件的子组件,所以还需要将 onSyncAttrUpdate 方法写了所有的 Page 定义中。
所有这些就是 minapp 的双向绑定的基本原理了。
等等,最后还有一件事:
wxml 模板,不能让用户每次写双向绑定的时候都要写那么复杂语句吧?当然不用,minapp 在编译时,会将模板做个简单的转化:
谢谢,文章到此结束,欢迎关注 minapp:
重新定义微信小程序的开发相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!推荐阅读:
事件模型的详解event loop如何使用以上就是微信小程序怎么实现数据双向绑定的详细内容,更多请关注php中文网其它相关文章!
微信
分享相关标签:
小程序 双向 数据本文原创发布php中文网,转载请注明出处,感谢您的尊重!
上一篇:
微信如何验证所有者
下一篇:
微信小程序的wx.request与Promise的结合使用相关文章相关视频修改微信号有什么影响吗?微信中共享实时位置什么意思数据库设计的基本原则是什么?微信小程序调用图片安全API微信小程序怎么实现数据双向绑定React 双向绑定 Mixin 源码阅读什么是微信小程序微信小程序HelloWorld创建微信小程序架构分析微信小程序View组件和Flexbox弹性盒模型 [温州做微信公众号]