小程序 数据代理(小程序商城制作一个需要多少钱)

网友投稿 587 2022-10-08

小程序 数据代理(小程序商城制作一个需要多少钱)

小程序 数据代理(小程序商城制作一个需要多少钱)

小程序 数据代理

微信开发工具导入项目

新建项目 -> 导入src文件 -> 预览效果

代码

proxy.js

const nativePage = Page const nativeComponent = Component Page = (options, key = 'onLoad') => { const native = options[key] options[key] = function () { this.ctx = proxy.call(this) return native && native.call(this) } key === 'onLoad' ? nativePage(options) : nativeComponent(options) } Component = options => Page(options, 'created') function proxy() { let pending = false const setData = () => { pending = true setTimeout(() => { this.setData(this.data, () => pending = false) }) } const handler = { get(target, key, receiver) { try { if (typeof target[key] === 'function') return Reflect.get(target, key, receiver) return new Proxy(target[key], handler) } catch (err) { return Reflect.get(target, key, receiver) } }, set(target, key, value, receiver) { if (!(Array.isArray(target) && key !== 'length')) !pending && setData() return Reflect.set(target, key, value, receiver) }, deleteProperty(target, key) { !pending && setData() return Reflect.deleteProperty(target, key) } } return new Proxy(this.data, handler) }

使用

在 app.js 中引入 proxy.js 文件

require('./vendor/proxy.js')

在 index 页面中的 index.js 中使用

onLoad: function () { this.ctx.motto = 'Hello Echo' this.ctx.user.name = 'Echo' }

在 movable 组件中的 movable.js 中使用

created: function () { this.ctx.visible = true }

截图预览

数据更新前 和 更新后 对比

原理说明

拦截数据变化,调用 this.setData 方法多条数据变化,合并一次更新代理对象绑定到 this.ctx 上下文中,同步更新 this.data 数据

如果觉得不错,请动动您的小拇指,star一下

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:(转)[Python]pip更换国内源
下一篇:[IOS]Force iphone app to restart programmatically?
相关文章

 发表评论

暂时没有评论,来抢沙发吧~