for( var i in data){
//data[i]["isShow"] = true;
app. $data. testData. push( data[ i]);
app. $data. testData[ i][ "isShow"]= true;
//app.$set(app.$data.testData[i],"isShow","true")
console. log( app. $data. testData);
}

该处代码的属性“isShow”在页面是不会实时响应的,昨天刚遇到这个问题,突然发现页面v-if绑定的“isShow”没响应了,然后开始找原因,定位到问题是当在上面循环中先将isShow属性添加到返回数据data上就不会出现这个问题了,这时候想到肯定使这2个操作导致最后的app.$data.testData不一样,在浏览器打印发现:

app.$data.testData.push(data[i]);
app.$data.testData[i]["isShow"]= true; 下,isShow属性没有get和set方法


data[ i][ "isShow"] = true;
app. $data. testData. push( data[ i]);

下,浏览器打印:


说明属性的响应需要有这2个方法存在。

用$set添加属性方法:

app. $set( app. $data 响应. testData[ i], "isShow", "true") //(data,key,value)


Logo

前往低代码交流专区

更多推荐