vue中数据更新变化,而页面视图未渲染的解决方案

时间: 2018-06-07阅读: 12289标签: 渲染

在使用vue的时候,我们都知道它是双向数据绑定的,但是在使用不熟的情况下,经常会遇到:data中的数据变化了,但是并没有触发页面渲染。下面就整理一些出现这种情况的场景以及解决办法。


场景一:子数组里的数据变化时,视图没有立即渲染。 

实例代码

<template v-for="a in arr">
	<template v-for="val in a">
		<span v-text="val"></span>
	</template>
</template>
<script>
export default{
  data:function(){
    return {
    	arr:[
    		[1,3],
    		[10,30],
    	]
    }
  },
  mounted:function(){
	this.arr[0]=[2,4];
	console.log(this.arr);
  },
}
</script>

打印可以看出arr中的数据是修改了的,但是页面视图并没有渲染。这表明利用索引直接设置一个项时,视图是不会渲染。

解决办法:

1、利用vue中的set方法:

//this.arr[0]=[2,4];
this.$set(this.arr,0,[2,4]);

2、利用Array.prototype.splice方法:  

//this.arr[0]=[2,4];  
this.arr.splice(this.arr[0], 1, [2,4]);

说明:

vue 只观察数组的变异方法。及只有变异方法才会触发视图更新。常用的如下: 

增加数据:push()      
修改/删除数据:splice()

除了上面2个方法,还包括:pop(),shift(),unshift(),sort(),reverse()等。

 

场景二:给对象额外添加一个数据字段时,视图没有立即渲染。

实例代码: 

<template v-if="obj">
	<span v-text="'性别:'+obj.sex"></span>
</template>
<script>
export default{
	data:function(){
	    return {
	    	name:'tony',age:'41',
	    	obj:{name:'tony',age:'41'},
	    }
	},
	created:function(){
		this.obj.sex="女";
	},
	mounted:function(){
		this.obj.sex="男";
		console.log(this.obj);
	},
}
</script>

打印可以看出obj中的数据是修改了的,但是页面视图并没有渲染。  这是由于sex为新添加的属性,不能响应。

解决办法: 

1、利用vue中的set方法:  

created:function(){
  //this.obj.sex="女";  
    this.$set(this.obj,"sex","女");
}

2、利用克隆对象的方式 

created:function(){
  //this.obj.sex="女";  
  var newobj=Object.assign({}, this.obj);//克隆给新对象
  newobj.sex="女";
  this.obj=newobj;//重新赋值
}

说明:

如果直接使用this.obj.sex="男"不会起作用,因为受 ES5 的限制,Vue.js 不能检测到对象属性的添加或删除。因为 Vue.js 在初始化实例时将属性转为 getter/setter。


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.fly63.com/article/detial/864

Vue.js中v-html渲染的dom添加scoped的样式

在vue.js中,要将一段字符串渲染成html,可以使用v-html指令。但是 官方文档 中的v-html部分也提醒了

原来 CSS 与 JS 是这样阻塞 DOM 解析和渲染的

估计大家都听过,尽量将 CSS 放头部,JS 放底部,这样可以提高页面的性能。然而,为什么呢?大家有考虑过么?很长一段时间,我都是知其然而不知其所以然,强行背下来应付考核当然可以,但实际应用中必然一塌糊涂

vue 修改变量值无法渲染到页面

开发中碰到这么个问题,修改对象中的属性无法渲染页面。直接操作ccc变量就是没问题的。直接贴我的代码。解决方法一:注意,第二个参数是字符串类型,切记。

vue从后台获取数据赋值给data,如何渲染更细视图

如果从服务端返回的数据量较少,或者只有几个字段,可以用vue的set方法,如果数据量较大,请直接看第二种情况。官网API是这样介绍的:Vue.set(target,key,value)

细说 Vue 组件的服务器端渲染

现在,前后端分离与客户端渲染已经成为前端开发的主流模式,绝大部分的前端应用都适合用这种方式来开发,又特别是 React、Vue 等组件技术的发展,更是使这种方式深入人心。

让页面更早的渲染:使用 preload 提升资源加载优先级

preload 是一个新的 Web 标准,旨在提高性能以及提供给 web 开发者更多的细粒度加载控制。它可以使开发者自定义加载逻辑而避免以 script 标签加载资源所带来的性能损耗。

CSS 渲染原理以及优化策略

提起 CSS 很多童鞋都很不屑,尤其是看到 RedMonk 2019 Programming Language Rankings 的时候,CSS 竟然排到了第七位。我们先来看看这张排行榜:

服务端渲染和客户端渲染:CSR和SSR

现在的web网站都是非常讲究用户体验,一般都会采用服务端渲染加客户端渲染一起实现功能。服务端渲染有利于搜索引擎优化(SEO),利于被网页爬虫抓取数据,多见于电商网站商品信息获取等。客户端渲染不利于搜索引擎优化

CSS加载会阻塞DOM树的解析和渲染吗?

css加载不会阻塞DOM树的解析 ; css加载会阻塞DOM树的渲染 ;css加载会阻塞后面js语句的执行,为了避免让用户看到长时间的白屏时间,我们应该尽可能的提高css加载速度

Vue渲染函数

使用v-else 指令来表示 v-if 的 else,v-else 元素必须紧跟在 v-if 或者 v-else-if元素的后面,否则它将不会被识别 :通常会复用已有元素而不是从头开始渲染(就近原则),key使得Vue渲染速度会变得非常快。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!