当前位置: 首页 > 微信相关

如何在开发微信小程序中实现数据双向绑定

发布日期:2020-08-12 09:07:49 分类:微信相关 阅读()来源:网络收集

好东西要多分享:

做网站就上魔艺客
摘要:在原生小程序开发中,数据流是单向的,无法双向绑定,除了官方wepy实现双向绑定还可以有别的方法实现。

在原生小程序开发中,数据流是单向的,无法双向绑定,在官方教程中利用wepy就可以实现双向绑定。但是,不用任何框架,就用原生的组件开发技术,同样可以实现双向绑定的功能。

小程序可以利用minapp框架实现双向绑定的原理,minapp是一款完全兼容原生小程序组件开发的框架。在minapp中,只需要在wxml模板中给组件的属性名后加上.sync就可以实现双向绑定。

首先,要使数据双向绑定,应该避免过多的数据源。在数据从上到下自然流动的情况下,如果每个组件中都维护它们自己的数据,而又要保持它们数据值的一致,这虽然可以做到,但实现过程并不会简单。但是也没必要说为了有一个统一的数据源就使用mobxredux来全局管理数据,这就有点杀鸡用牛刀的感觉了。由于双向绑定只存在于父子组件之间,而数据又是从父到子传递的,所以可以优先使用父组件中的数据为数据源,子组件每次更新数据并不更新它自己内部的数据,而是通过事件机制触发父组件更新它的数据,而父组件更新数据后又会将更新的数据自然地传给子组件,由此达到数据的双向流动!


并不是所有数据都需要双向绑定,也并不是所有数据都是对外的,子组件还可以有它自己的一个内部数据。所以这就涉及到我们要说的第二个问题:区分哪些数据需要双向绑定,哪些数据又需要子组件自己维护 。

vue中要实现双向绑定,需要在模板中做特殊处理。比如要将父组件的parentAttr 双向绑定到子组件的childAttr上,需要在父组件的模板中这样写:

但是小程序并没有这样的简单的语法,小程序的 wxml 语言的属性名中甚至都不允许出现 . 这样的字符。回到我们的问题上来,子组件需要知道哪些属性需要双向绑定,哪些属性需要自己维护 , 给模板加个字段( syncAttrMap )专门来告诉子组件需要双向绑定的数据集合不就行了么。如,可以将上面的示例写成微信小程序支持的写法:

// 子组件

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 来实现上面的所有功能,如:

//BaseComponent

constBaseComponent = {

properties: {

syncAttrMap: String

},

methods: {

setDataSmart() {

// ...

},

onSyncAttrUpdate() {

// ...

}

}

}

然后将 BaseComponent mixin 到每个组件的对象上去就可以了;另外小程序中还有一个特殊的组件: Page ,虽然 Page Component 结构是两样的,但它也应该算是一个组件,不过它一定是父组件,不可能是别的组件的子组件,所以还需要将 onSyncAttrUpdate 方法写了所有的 Page 定义中。这就是minapp的双向绑定的基本原理。


推荐阅读:微信小程序开发有哪些方法在本地调试

微信小程序测评



声明: 文章内容及图片部分全部摘自网络,在此分享供读者参考和借鉴,不代表酷雷的观点。文章、图片等内容如涉嫌侵权,请联系我们删除,谢谢!带有原创标签的属于酷雷原创文章,未经允许不得转载!

标签:

我要说一说

加载中~

相关推荐

您好,很高兴为您服务!
广告合作
投诉建议
联系站长

客服热线:15821432298

扫码加好友,优惠等你来!