2、参数和变量名称一致,可用一个值代替(es6新语法特性)
3、可以设置一个或多个data数据.
4、key可以以数据路径的形式给出(路径形式的key必须带引号)(经小程序更新后,现已支持不加引号的写法)
5、key值可以为变量,为变量的时候要用[ ]引起来
注意:deletedtodo为变量作为key值的时候要用 [] 包裹起来。
6、直接修改this.data,虽然会改变数据,但是页面不会重新渲州悉正染,无法改变页面状态,会造成数据不一致的情况
7、单次设置的数据不能超过1024KB,请尽量避免一次设置过多的数据
8、不需要在this.data中预先定义,使用setData()方法会自动创建该数据
name在this.data中未定义,但是这种写法不会报错,而且还会在this.data.zhong创建name这条数据。可以用this.data.name获取到该条数据
1、数组的增加:
我们可以自己组装一个对象如上图的obj,然后用push()方法将其添加到数据的最后。注意push的数据的index是+1的,也就是说原本数组中index依次为0,1,2,新增加的就是3,依次类推册悔。如果想将数据插入到数据某个位置,那么可以合理运用concat()的方法将数据合并到数据中。
也可以用splice()方法添加,第一个参数是插入的位置,第二个参数设为0,则为添加,若为大于0的的数字则为要删除的个数,第三陆闷个参数只有在第二个参数为0是使用,是添加的内容。这种方法非常灵活,只需要改变第一个参数就可以将内容添加到数据的任何一个地方。下面附上splice的用法;
2、数组的删除:
删除也是用splice()方法实现的,ceshi.splice(1,1)就是从index为1的位置开始,删除1个元素。splice()用法参上。
3、数组的修改:
将key值以数据路径的形式赋值,可以达到修改数据中的某一条,此处,我们只将ceshi[0].value的值改变为'oooo',其他数据未发生变化。
也可以用这种方法修改数组的参数,对这种方法有疑问的可以参考setData()第二条。
app.baseGet是异步 *** 作下滑胡边 console.log(that.data.userInfo)//这里打并孙印undefine
打印时 ,get请求响应函数还绝让链没返回
用setTimeout给下边打印,加个延时就能打印了
官方
先看一下官方对于 this.data 和 this.setData({}) 的定义与用法
知识乱伍点
this.data 是用来获取页面data对象,仅会改变数据,无法改变页面的状态凳陪尺,可能会造成数据不一致;
this.setData({}) 是用来修改数据,不仅会改变数据,而且还会改变视图;
问题
实际自己在学习过程中,遇到一个问题,下拉刷新的方法当中,用 this.data 与 this.setData({}) ,在数据显示上并没有什么不同,学习的视频中,授课老师用的是this.data,这个地方我自己也没有搞清楚是为什么
*** 作效果:
this.data
this.setData({})
可以看出来,两者使用并没有什么明显的区别。
总结
实际使用当中按照上面 知识点 部分加粗部分去执行,肯定是没有错的,涉及到页面数据更新的,使用**this.setData({}) **,在js中枣高使用data数据时使用****this.data.属性 。****
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)