this.$set()的主要功能是解决改变数据时未驱动视图的改变的问题,也就是实际数据被改变了,但我们看到的页面并没有变化
vue和uniapp语法大部分都是相同的,uniapp是针对移动端的,并且可以开发小程序,最重要的区别是uniapp开发小程序时不能操作dom,注意,是不能,不是不建议,操作DOM后编译代码时会报错。
先写下数据
items: [
{ message: "one", id: "1" },
{ message: "two", id: "2" },
{ message: "three", id: "3" }
]
通常我们改变某个message会这么写
this.items[0].message='one1'; //这么写一般是可以更新视图的 我只是给举this.$set()用法的例子
使用this.$set()时
this.$set(this.items[0],'message','one1');//改成数字类型就不用了加引号
有的时候我们可能一次改多个
this.items[0]={ message: "one3", id: "13" };
使用this. s e t ( ) 时 , 格式 t h i s . set()时, 格式this. set()时,格式this.set( target, key, value )
this.$set( this.items, 0, { message: "one3", id: "13" })
给大家复现一种不渲染的例子:当前我们数组内有三条对象,那么我想加一条,并且我就不用类似push的东西,还要能渲染到视图普通写法 不渲染
his.items[3]={ message: "four", id: "4" };//数据已经被改变 但是视图层没渲染,我们看不到
使用this. s e t ( ) 时 , 格式 t h i s . set()时, 格式this. set()时,格式this.set( target, key, value )
this.$set( this.items, 3, { message: "four", id: "4" })//这样就可以渲染到视图层了
原文地址:https://www.cnblogs.com/birdysilhouette/p/14793709.html