小程序SetData同步还是异步问题

本文探讨了小程序中setData函数的行为特点,对比React中的setState方法,解释了setData改变this.data的同步性和渲染视图层的异步性,并分析了这种设计背后的性能考量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

小程序SetData同步还是异步

刚进新公司不久,学了几天小程序,由于之前是用React的,所以学起来相对轻松,但是也有许多不同,不明白的点.


问题
React中,this.setState是异步的,改变state之后是不能立马获取到改变之后的值的.

this.setState({
    name:'zhang'
})
console.log(this.state.name);//不能立马获取到新的state值

小程序中:因为React的原因,所以以为小程序中也是不能立马获取到新的data值,但是…

this.setData({
    name:'zhang'
})
console.log(this.data.name);//可以立马获取到新的data值

解答:
查看小程序官方文档
这里写图片描述

可以看到 setData函数是
1. 将数据从逻辑层发送到视图层是异步
2. 改变this.data是同步
也就是说改变值是同步的,改变值之后渲染页面是异步的,
应该是为了提高性能,不可能改变一次数据渲染一次页面,等所有data改变完之后一块渲染页面.
刚学习小程序不久,水平有限,希望批评与指正.

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值