美文网首页小程序时光轴
小程序 setData 的详解

小程序 setData 的详解

作者: 侯工 | 来源:发表于2019-04-16 17:55 被阅读1次

    一、setData()方法:

    1、参数接受一个对象,以key,value的形式表示;
    2、参数和变量名称一致,可用一个值代替(es6新语法特性)
    3、可以设置一个或多个data数据.

    
    this.setData({
       list:'change data',
       info:'change data'
    })
    

    4、key可以以数据路径的形式给出(路径形式的key必须带引号)(经小程序更新后,现已支持不加引号的写法)

    this.setData({
        'list[0].title' : 'change data',   //数据路径key必须带''号
        'list[0].num' : 'change data'      //数据路径key必须带''号
    })
    

    5、key值可以为变量,为变量的时候要用[ ]引起来

    
    page({
      data:{
        todos:[{id:0,text:'abc',isDelete:false}]
      },
      change(e){
        var index = e.currentTarget.dataset.id;
        var deletedtodo='todos['+index+'].idDelete';
        this.setData({
           [deletedtodo]:true
        })
      }
    })
    

    注意:deletedtodo为变量作为key值的时候要用 [] 包裹起来。

    6、直接修改this.data,虽然会改变数据,但是页面不会重新渲染,无法改变页面状态,会造成数据不一致的情况

    7、单次设置的数据不能超过1024KB,请尽量避免一次设置过多的数据

    8、不需要在this.data中预先定义,使用setData()方法会自动创建该数据

    this.setData({
        name:'张三'   //name在this.data中未定义,但不会报错
    })
    

    name在this.data中未定义,但是这种写法不会报错,而且还会在this.data.zhong创建name这条数据。可以用this.data.name获取到该条数据

    二、对数组的操作,json操作和数组一样。

    1、数组的增加:

    我们可以自己组装一个对象如上图的obj,然后用push()方法将其添加到数据的最后。注意push的数据的index是+1的,也就是说原本数组中index依次为0,1,2,新增加的就是3,依次类推。如果想将数据插入到数据某个位置,那么可以合理运用concat()的方法将数据合并到数据中。

    也可以用splice()方法添加,第一个参数是插入的位置,第二个参数设为0,则为添加,若为大于0的的数字则为要删除的个数,第三个参数只有在第二个参数为0是使用,是添加的内容。这种方法非常灵活,只需要改变第一个参数就可以将内容添加到数据的任何一个地方。下面附上splice的用法;

    Splice

    • splice()方法向/从数组中添加/删除元素,然后返回被删除的元素组成的数组。
    • 用于数组对象。
    • arr.splice(index, howmany, item1,…, itemX)
    • 注意:这个方法会对原数组做出修改。获得的也是新数组。

    2、数组的删除:

    删除也是用splice()方法实现的,ceshi.splice(1,1)就是从index为1的位置开始,删除1个元素。splice()用法参上。

    3、数组的修改:

    将key值以数据路径的形式赋值,可以达到修改数据中的某一条,此处,我们只将ceshi[0].value的值改变为'oooo',其他数据未发生变化。

    也可以用这种方法修改数组的参数,对这种方法有疑问的可以参考setData()第二条。

    相关文章

      网友评论

        本文标题:小程序 setData 的详解

        本文链接:https://www.haomeiwen.com/subject/tvebwqtx.html