vue2.0,通过方法改变请求的数据,没有渲染视图的解决办法
2018-04-19 本文已影响49人
无痕Q
近期做项目,碰到一个问题,
mounted钩子里ajax请求的数据,在methods里通过某方法改变array[i]的数据时,
用普通的语法:
-------------------this.array[i].'属性名'=值,
并不能重新渲染视图,
经过各种search,有如下合适方法:
1,this.$set(this.array,i,{'属性名',值}),
该方法弊端:this.array[i]的其他属性被改变为空,
(当然,你可以在this.$set()的第三个参数中将一系列属性都重新设置一遍);
2,this.$set(this.array[i],'新属性名',值),
该方法需要在视图中加入新属性的判断或展示区域,
下面是本人项目实例:
-------html:

-------js:

目的:重新渲染this.combo.works[i].size