首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >小程序的小技巧之 computed 计算属性

小程序的小技巧之 computed 计算属性

作者头像
腾讯NEXT学位
发布2019-02-01 19:51:25
4.2K0
发布2019-02-01 19:51:25
举报

小程序的出身,基于安全和管控的考虑,使用了双线程的设计,同时对于 DOM 操作、动态创建 DOM 这些都隔离了。在写代码的时候,模版语法不支持函数计算,computed 的方法就显得十分重要。

自定义组件


小程序的自定义组件涉及功能很多,这篇只针对computed展开来讲。

computed比较适合较复杂逻辑的计算,同时在小程序无法在模板里使用methods这样的场景下,计算属性的需求就更强烈了。

behaviors

自定义组件中,提供了behaviors的使用和定义。

从官方文档我们能看到:

behaviors是用于组件间代码共享的特性,类似于一些编程语言中的“mixins”或“traits”。 每个behavior可以包含一组属性、数据、生命周期函数和方法,组件引用它时,它的属性、数据和方法会被合并到组件中,生命周期函数也会在对应时机被调用。每个组件可以引用多个behavior

简单来说,我们能通过behaviors来重构Component的能力。

如果说,我们能“混入”Component,其实基本很多能力都能实现啦。其实我们自己封装一层的MyComponent也能达到一定的效果,但是这样的拓展性会变得很糟。

通过behaviors的方式,每个组件可以按需引入自己需要的behavior啦。

computed 实现

我们来梳理下这里的逻辑,我们需要一个computed能力,需要处理的主要是:setData的时候,根据computed来计算哪些数据需要处理。

所以我们要做的是:

  1. 记下来需要computed的变量。
  2. 在每次setData之前,看看是否包含到需要computed的变量,匹配到了就进行computed处理。
  3. 使用处理后的数据,进行setData

官方已经提供了计算属性实现的behavior,大家也可以尽情翻看实现的源码,和使用这种拓展能力。

Page 的超集


hack 实现 Page computed 能力

想必大家都会有疑惑,Component里支持behaviors,但是Page依然写起来很不方便呀。虽然所有的Page最终也能通过Component来实现,但是这样是否需要多包装一层呢?

答案是不用。

使用 Component 构造器构造页面

ComponentPage的超集,因此可以使用Component构造器构造页面。

同样的,我们来看看官方文档:

事实上,小程序的页面也可以视为自定义组件。因而,页面也可以使用Component构造器构造,拥有与普通组件一样的定义段与实例方法。但此时要求对应json文件中包含usingComponents定义段。

也就是说,我们这样的页面:

123456789101112131415

Page({data: {logs: []},onLoad(query) {// 如访问页面`/pages/index/index?paramA=123&paramB=xyz`,如果声明有属性(`properties`)`paramA`或`paramB`,则它们会被赋值为`123`或`xyz`query.paramA // 页面参数 paramA 的值query.paramA // 页面参数 paramB 的值this.setData({logs: (wx.getStorageSync("logs") || []).map((log: number) => {return formatTime(new Date(log));})});}});

可以这么写:

123

{"usingComponents": {}}

12345678910111213141516171819202122

Component({// 组件的属性可以用于接收页面的参数properties: {paramA: Number,paramB: String,},data: {logs: []},methods: {onLoad() {// 如访问页面`/pages/index/index?paramA=123&paramB=xyz`,如果声明有属性(`properties`)`paramA`或`paramB`,则它们会被赋值为`123`或`xyz`this.data.paramA // 页面参数 paramA 的值this.data.paramB // 页面参数 paramB 的值this.setData({logs: (wx.getStorageSync("logs") || []).map((log: number) => {return formatTime(new Date(log));})});}}});

这样,我们就能愉快地使用behaviors啦。

12345678910111213141516171819202122232425262728

const computedBehavior = require("miniprogram-computed");Component({behaviors: [computedBehavior],data: {logs: []},computed: {logsAfterComputed() {// 计算属性同样挂在 data 上,每当进行 setData 的时候会重新计算// 比如此字段可以通过 this.data.b 获取到return this.data.logs.map(x => {return {log: x,logAfterCompute: x + "logAfterCompute"};});}},methods: {onLoad() {this.setData({logs: (wx.getStorageSync("logs") || []).map((log: number) => {return formatTime(new Date(log));})});}}});

使用Component构造器构造页面,需要注意:

组件的属性可以用于接收页面的参数,如访问页面/pages/index/index?paramA=123&paramB=xyz,如果声明有属性(properties)paramAparamB,则它们会被赋值为123xyz。(可参考官方代码示例)

页面的生命周期方法(即on开头的方法,如上面的onLoad),应写在methods定义段中。

这样,你就能愉快地在代码里面使用computed计算属性啦~

更多的,也可以参考本人的wxapp-typescript-demo中的log page,后续也会持续更新方便好用的能力 demo。

文章来源:腾讯工程师 王贝珊

「人人都会微信小程序」限时特惠!

上线自己的小程序,抢领百万奖学金

微信官方证书召唤你,腾讯offer等你拿

腾讯大牛手把手教学,0基础快速上手小程序

腾讯NEXT学院

求职干货 | 前辈blog  | 前端课程

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-02-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 腾讯NEXT学院 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 小程序的出身,基于安全和管控的考虑,使用了双线程的设计,同时对于 DOM 操作、动态创建 DOM 这些都隔离了。在写代码的时候,模版语法不支持函数计算,computed 的方法就显得十分重要。
    • 自定义组件
      • behaviors
      • computed 实现
    • Page 的超集
      • hack 实现 Page computed 能力
      • 使用 Component 构造器构造页面
相关产品与服务
数据库一体机 TData
数据库一体机 TData 是融合了高性能计算、热插拔闪存、Infiniband 网络、RDMA 远程直接存取数据的数据库解决方案,为用户提供高可用、易扩展、高性能的数据库服务,适用于 OLAP、 OLTP 以及混合负载等各种应用场景下的极限性能需求,支持 Oracle、SQL Server、MySQL 和 PostgreSQL 等各种主流数据库。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档