小程序解决方案 Westore - 组件、纯组件、插件开,微信小程序自定义组件找不到

来源:未知 浏览 147次 时间 2021-06-09 07:06

数据流转

先上一张图看清 Westore 怎么解决小程序数据难以管理和维护的问题:

非纯组件的话可以直接省去 triggerEvent 的过程直接修改 store.data 并且 update百度索引量直接修改 store.data 并且 update形成缩减版单向数据流。

组件

这里说的组件便是自定义组件使用原生小程序的开发格式如下:

Component({ properties: { }, data: { }, methods: { } }) 使用 Westore 之后: import create from '../../utils/create' create({ properties: { }, data: { }, methods: { } })  

看着差别不大百度索引量使用原生小程序的开发格式如下:

Component({ properties: { }, data: { }, methods: { } }) 使用 Westore 之后: import create from '../../utils/create' create({ properties: { }, data: { }, methods: { } })  

看着差别不大但是区别:

Component 的方式使用 setData 更新视图 create 的方式直接更改 store.data 然后调用 update create 的方式可以使用函数属性Component 不可以如: export default { data: { firstName: 'dnt', lastName: 'zhang', fullName:function(){ return this.firstName + this.lastName } } }  

绑定到视图:

<view>{{fullName}}</view>

小程序 setData 的痛点:

使用 this.data 可以获取内部数据和属性值但不要直接修改它们应使用 setData 修改

setData 编程体验不好很多场景直接赋值更加直观方便

setData 卡卡卡慢慢慢JsCore 和 Webview 数据对象来回传浪费计算资源和内存资源

组件间通讯或跨页通讯会把程序搞得乱七八糟变得极难维护和扩展

没使用 westore 的时候经常可以看到这样的代码:

使用完 westore 之后:

上面两种方式也可以混合使用。

可以看到westore 不仅支持直接赋值而且 this.update 兼容了 this.setData 的语法但性能大大优于 this.setData再举个例子:

this.store.data.motto = 'Hello Westore' this.store.data.b.arr.push({ name: 'ccc' }) this.update()  

等同于

this.update({ motto:'Hello Westore', [`b.arr[${this.store.data.b.arr.length}]`]:{name:'ccc'} })  

这里需要特别强调百度索引量再举个例子:

this.store.data.motto = 'Hello Westore' this.store.data.b.arr.push({ name: 'ccc' }) this.update()  

等同于

this.update({ motto:'Hello Westore', [`b.arr[${this.store.data.b.arr.length}]`]:{name:'ccc'} })  

这里需要特别强调虽然 this.update 可以兼容小程序的 this.setData 的方式传参但是更加智能百度索引量但是更加智能this.update 会先 Diff 然后 setData。原理:

纯组件

常见纯组件由很多如 tip、alert、dialog、pager、日历等与业务数据无直接耦合关系。

组件的显示状态由传入的 props 决定与外界的通讯通过内部 triggerEvent 暴露的回调。

triggerEvent 的回调函数可以改变全局状态实现单向数据流同步所有状态给其他兄弟、堂兄、姑姑等组件或者其他页面。

Westore里可以使用 create({ pure: true }) 创建纯组件(当然也可以直接使用 Component)比如 :

import create from '../../utils/create' create({ pure : true, properties: { text: { type: String, value: '', observer(newValue, oldValue) { } } }, data: { privateData: 'privateData' }, ready: function () { console.log(this.properties.text) }, methods: { onTap: function(){ this.store.data.privateData = '成功修改 privateData' this.update() this.triggerEvent('random', {rd:'成功发起单向数据流' + Math.floor( Math.random()*1000)}) } } })  

需要注意的是加上 pure : true 之后就是纯组件组件的 data 不会被合并到全局的 store.data 上。

组件区分业务组件和纯组件他们的区别如下:

业务组件与业务数据紧耦合换一个项目可能该组件就用不上除非非常类似的项目

业务组件通过 store 获得所需参数通过更改 store 与外界通讯

业务组件也可以通过 props 获得所需参数通过 triggerEvent 与外界通讯

纯组件与业务数据无关可移植和复用

纯组件只能通过 props 获得所需参数通过 triggerEvent 与外界通讯

大型项目一定会包含纯组件、业务组件。通过纯组件百度索引量通过 triggerEvent 与外界通讯

大型项目一定会包含纯组件、业务组件。通过纯组件可以很好理解单向数据流。

小程序插件

小程序插件是对一组 JS 接口、自定义组件或页面的封装用于嵌入到小程序中使用。插件不能独立运行必须嵌入在其他小程序中才能被用户使用;而第三方小程序在使用插件时也无法看到插件的代码。因此插件适合用来封装自己的功能或服务提供给第三方小程序进行展示和使用。

标签: 程序组件使用create