微信小程序的setData

由于微信小程序诞生于vue.js和react.js之后,所以他们在当初设计代码架构的时候也是借鉴了vue.js和react.js的想法,也遵循的组件化的方式,延用了setData的机制去把视图层和逻辑层做一个“中转站”两边连接起来。但是这种机制一直存在性能上的问题,微信小程序也不例外。先看一张图:

这张图大体描述了一下setData的工作原理,当程序开始触发setData操作的时候,先把数据做成字符串形式传递,同时把转换后的数据拼接成js脚本形式,接下来这个js脚本都被2边提供的evaluateJavascript所实现,那为什么要分webview和javascriptCore去执行呢?先说一下这2个是干嘛的

webview和JavascriptCore

在微信打开小程序的时候,会先起了2个线程一个是view Thread,一个是AppService Thread, 通俗讲前者是视图层,后者是逻辑层。它们是独立的,各自职能不一样,但它们是并行操作的,小程序的页面展示都是嵌套在webview里面的,

在小程序入口文件app.js里面有一个pages配置项,例如:

pages: [

‘pages/indexBar‘,

‘pages/friends/friends‘

]

这里配置了多少个页面,小程序都会预先加载多少个页面对应的webview,这是view Thread所做的操作,同时AppService Thread也是对应的页面做了逻辑层面的加载操作,会根据小程序的生命周期依次做逻辑操作,这里也会和view Thread有数据传输交互,下面一张图可以很详细的描述view Thread和AppService Thread同时加载一个页面的所有过程

在架构上,WebView 和 JavascriptCore 都是独立的模块,数据是不能直接共享的,为了让数据共享,WebView和JavascriptCore都提供了evaluateJavascript来实现,(在安卓机上老早以前提供的不是evaluateJavascript来调用js操作的,到sdk19以上采用evaluateJavascript方法)

由于有了以上的机制,造成了setData存在一些性能上的问题,如果频繁地调用,WebView和JavascriptCore执行并发多了就会造成用户体验卡顿的现象,为了减少性能开销,建议尽量对setData进行合并操作:


1
2
3


this.setData({ one: ‘1‘ })
this.setData({ two: ‘2‘})
this.setData({ three: ‘3‘ })

修改成:

this.setData({
     one: ‘1‘,
     two: ‘2‘,
     three: ‘3‘,
})

这样就减少了拼接js脚本的次数,从而提升了性能。

在Taro小程序框架里面更新数据时调用的 setState 为异步方法,自动对同一个事件循环多次setState调用,然后进行合并处理,还会对数据进行diff优化,自动剔除那些未改变的数据。

原文地址:https://www.cnblogs.com/kuailingmin/p/11392704.html

时间: 2024-10-07 19:45:10

微信小程序的setData的相关文章

微信小程序 this.setData() 详解

1.定义 setData()函数用于将逻辑层数据发送到视图层,同时对应的改变this.data的值. 2.setData()参数格式 接受一个对象,以键(key)值(value)的方式改变值. 其中,key十分灵活,以数据路径的方式给出 -- array[2].message,a.b.c.d,并且不需要在 this.data 中预先定义. 3.实例 Page({ data: { text: 'init data', array: [{text: 'init data'}], object: {

微信小程序中用setData修改一个对象的属性值

1. Page({    data: {      items:{ //items为一个对象,is_like和like分别为其两个属性     is_like: 0,    like: 0  } }, likes: function () { var is_like ="items.is_like"; //先用一个变量,把items.is_like用字符串拼接起来 var like = "items.like"; if (this.data.items.is_lik

微信小程序setData的使用,通过[...]进行动态key赋值

首先先介绍一下微信小程序Page.prototype.setData(Object data, Function callback)的讲解: setData函数用于将数据从逻辑层发送到视图层(异步),同时改变对应的this.data的值(同步) 微信小程序官网文档只对字符串,数字,数组和对象类型的数据通过对setData进行了修改,却没有对动态数据进行讲解,在这里我就针对静态数据以及动态数据的修改进行讲解. 这里关键是动态数据修改,通过使用[...]: "..."进行动态数据赋值,如下

微信小程序setData复杂数组的更新、删除、添加、拼接

众所周知,微信小程序里所有对数据的修改只有在setData里修改才会在页面上渲染.在此分享小程序里复杂数组的更新.删除.添加.拼接 初始数据 数组嵌套对象 data: { cartList = [{ id: 1, goods: {id: 1, name: 'wechat'}, checked: true }, { id: 2, goods: {}, checked: false }, { id: 3, goods: {}, checked: true }] }, 索引部分删除 1 let ind

微信小程序开发初探

一.关于微信小程序 1.1 小程序诞生的背景 张小龙说道: (1)一切以用户价值为依归→用户是微信的核心,所以微信中没有很多与客户无关的功能,比如QQ中的乱七八糟一系列东西. (2)让创造发挥价值→所有围绕微信的创造比如公众号都应该发挥其应有的价值. (3)用完即走的高效服务→这一点就厉害了word天,微信要打造一个以微信为中心的生态链,不以绑定用户为目标.比如生活中有一些不太常用的app,我们可能一年也使用不了几次,但是有时候就需要用到,微信就想要提供这样一个平台,让你可以在微信中使用这中所谓

微信小程序(5)--阅读器

最近用微信小程序写了一个图书阅读器,可以实现左右滑动翻页,按钮翻页,上下滚动,切换背景,控制字体大小.以及记住设置好的状态,如页面再次进来保留上次的背景色和字体大小. 由于暂时没有真实的数据接口,所以我用了静态数据. <!-- 文本 --> <view class="container" style="background:{{bodyColor}}"> <!-- 中间层,点击,头部底部显示 --> <view class=

微信小程序(4)--二维码窗口

微信小程序二维码窗口: <view class="btn" bindtap="powerDrawer" data-statu="open">button</view> <!--mask--> <view class="drawer_screen" bindtap="powerDrawer" data-statu="close" wx:if=&qu

微信小程序实例教程(一)

序言 开始开发应用号之前,先看看官方公布的「小程序」教程吧!(以下内容来自微信官方公布的「小程序」开发指南) 本文档将带你一步步创建完成一个微信小程序,并可以在手机上体验该小程序的实际效果.这个小程序的首页将会显示欢迎语以及当前用户的微信头像,点击头像,可以在新开的页面中查看当前小程序的启动日志. 1. 获取微信小程序的 AppID 首先,我们需要拥有一个帐号,如果你能看到该文档,我们应当已经邀请并为你创建好一个帐号.注意不可直接使用服务号或订阅号的 AppID. 利用提供的帐号,登录https

微信小程序豆瓣电影项目的改造过程经验分享

在学习微信小程序开发过程中,一部分的难点是前端逻辑的处理,也就是对前端JS的代码编辑:一部分的难点是前端界面的设计展示:本篇随笔基于一个豆瓣电影接口的小程序开源项目进行重新调整,把其中遇到的相关难点和改进的地方进行讨论介绍,希望给大家提供一个参考的思路,本篇随笔是基于前人小程序的项目基础上进行的改进,因此在开篇之前首先对原作者的辛劳致敬及感谢. 1.豆瓣电影接口的小程序项目情况 豆瓣电影接口提供了很多相关的接口给我们使用,豆瓣电影接口的API地址如下所示:https://developers.d