vue添加新属性不更新原因

一:

在我们使用vue进行开发的过程中,可能会遇到一种情况:当生成vue实例后,当再次给数据赋值时,有时候并不会自动更新到视图上去;

当我们去看vue文档的时候,会发现有这么一句话:如果在实例创建之后添加新的属性到实例上,它不会触发视图更新。如下代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>vue $set</title>
<script src="https://static.runoob.com/assets/vue/1.0.11/vue.min.js"></script>
</head>
<body>
<div id="app">
  姓名:{{ name }}<br>
    年龄:{{age}}<br>
    性别:{{sex}}<br>
    说明:{{info.content}}
</div>
<!-- JavaScript 代码需要放在尾部(指定的HTML元素之后) -->
<script>
var data = {
    name: "简书",
    age: ‘3‘,
    info: {
        content: ‘my name is test‘
    }
}   
var key = ‘content‘;
var vm = new Vue({
    el:‘#app‘,
    data: data,
    ready: function(){
        //Vue.set(data,‘sex‘, ‘男‘)
        //this.$set(‘info.‘+key, ‘what is this?‘);
    }
});
data.sex = ‘男‘;
</script>
</body>
</html>
运行结果:

姓名:简书
年龄:3
性别:
说明:my name is test
为什么会这样呢?当去查对应文档时,你会发现**响应系统 **,把一个普通 Javascript 对象传给 Vue 实例来作为它的 data 选项,Vue 将遍历它的属性,用 Object.defineProperty 将它们转为 getter/setter,如上示例,将data在控制台打印出来会发现:

data打印结果

在age及name都有get和set方法,但是在sex里面并没有这两个方法,因此,设置了sex值后vue并不会自动更新视图;

解决方法:

<script>
var data = {
    name: "简书",
    age: ‘3‘,
    info: {
        content: ‘my name is test‘
    }
}   
var key = ‘content‘;
new Vue({
    el:‘#app‘,
    data: data,
    ready: function(){
        Vue.set(data,‘sex‘, ‘男‘);
        this.$set(‘info.‘+key, ‘what is this?‘);
    }
});
</script>
1、通过Vue.set方法设置data属性,如上:

Vue.set(data,‘sex‘, ‘男‘)
2、您还可以使用 vm.$set实例方法,这也是全局 Vue.set方法的别名:

var key = ‘content‘; //这种主要用于当对象中某个属性值动态生成时处理方式
this.$set(‘info.‘+key, ‘what is this?‘);
 或
this.$set(‘info.content‘, ‘what is this?‘);
二:

vue教程中有这样一个注意事项:

第一种具体情况如下:

运行结果:

当利用索引改变数组某一项时,页面不会刷新。解决方法如下:

运行结果:

三种方式都可以解决,使用Vue.set、vm.$set()或者数组的splice方法。

在做项目的过程中,有个发现,先上代码:

第一个数组通过利用下标改变第二项,第二个数组使用$set()方法改变第二项,根据上面的代码,我们会知道:第一个数组的第二项改变不会在页面更新,只有第二个数组的更改会在页面更新。然而结果却是:

两个数组的的改变都在页面更新了。。

也就是说,$set()方法调用时,页面会全部更新一遍。

三:

<!DOCTYPE html>
<html>

<head>
        <meta charset="utf-8">
        <title>Vue.set使用</title>
        <style>
            .list .active {
                background-color: #E35885;
            }
        </style>
        <script type="text/javascript" src="js/vue.js"></script>
    </head>

<body>
        <div id="app">
            <button type="button" v-on:click="getList()">获取列表并添加新属性</button>
            <ul class="list" v-if="showList">
                <li v-for=‘(item,index) in List‘ v-bind:class=‘{active:item.active}‘ v-on:click="beActive(index)">{{item.name}}</li>
            </ul>
        </div>

<script>
            Vue.config.devtools = true;

var app = new Vue({
                el: ‘#app‘,
                data: {
                    showList: false,
                    List: [{
                        name: "选项1"
                    }, {
                        name: "选项2"
                    }, {
                        name: "选项3"
                    }]
                },
                methods: {
                    getList: function() {
                        let len = this.List.length;
                        for(let i = 0; i < len; i++) {
                            this.$set(this.List[i], ‘active‘, false);
                        }
                        this.List[0].active = true;
                        this.showList = true;
                    },
                    beActive: function(index) {
                        let len = this.List.length;
                        for(let i = 0; i < len; i++) {
                            this.List[i].active = false;
                        }
                        this.List[index].active = true;
                    }
                }
            })
        </script>

</body>

</html>
---------------------
作者:歪歪100
来源:CSDN
原文:https://blog.csdn.net/weixin_41646716/article/details/81092253
版权声明:本文为博主原创文章,转载请附上博文链接!

原文地址:https://www.cnblogs.com/airen123/p/10037600.html

时间: 2024-10-01 10:57:28

vue添加新属性不更新原因的相关文章

Swift学习之UIView延展添加新属性left,right,top,bottom,width,height,centerx,centery

import Foundation import UIKit import CoreGraphics extension UIView{ var left:CGFloat{ set{ var frame = self.frame frame.origin.x = newValue self.frame = frame } get{ return self.frame.origin.x } } var top:CGFloat{ set{ var frame = self.frame frame.o

动态往json数据里添加新属性

/* orderBy排序包括其它过滤器都只在原本json数据就存在的情况下才能起作用 表头中单行的产品总价是通过数量*单价计算出来的json数据中并没有给出 所以我们要自己创建一个 用sum表示*/ /*此时打印出json数据 里面每一个object对象都增加了一个sum*/ $scope.sum=function(data){ angular.forEach($scope.data,function(elem,$index){ elem.sum=elem.count*elem.price; /

如何给一个响应式数据添加一个属性 this.$set

this.$set(this.data,”key”,value’) Vue.set(vm.items,2,"ling") : 表示 把vm.items  这个数组的下标为2 的元素,改为"ling" Vue.set(vm.person,"age","26") Vue.set()向响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新.它必须用于向响应式对象上添加新属性,因为 Vue 无法探测普通的新增属性 (

vue 添加对象的新属性的方法

和数组一样,Vue 不能检测到对象属性的添加或删除.由于 Vue 会在初始化实例时对属性执行 getter/setter 转化过程,所以属性必须在 data 对象上存在才能让 Vue 转换它,这样才能让它是响应的. 两种不同情况下使用的方法: Vue.set(object, key, value) Vue.set(vm.someObject, 'b', 2) vm.$set this.$set(this.someObject,'b',2) 如果想向已有对象上添加一些属性,例如使用 Object.

VUE不能对新增属性监测更新

1 data () { 2 return { 3 data:{}, 4 } 5 }, 6 method:{ 7 if(data.code==0){ 8 this.loading = false; 9 this.data = data.data; 10 this.data.list.forEach(item =>{ 11 item.selected = false; 12 }) 1 checked(item){ 2 if(item.selected){ 3 item.selected = fals

小习html5为表单添加的新属性

输入框html5新增属性 在学习任何一种语言时都提到“渐进增强”原则,说白了就是兼容性有木有.虽然html5一些新属性在实际使用中受到限制,但是依然阻挡不了伟大的同伴们学习的脚步.近来有点儿忙,这是2016年第一篇文章.内容比较简单只是了解学习. 输入框按输入的内容分,也就是单行输入和多行输入,既是<input type="">和<textarea></textarea> <textarea></textarea>标签属性 a

数组添加新的属性,旧的数组的属性提到新的数组里去

1.数组添加新的属性: 1.1:先建一个数组: var oldArr=[{name:'li'},{name:'hi'},{name:'us'}] 1.2:为这个数组添加一个新的属性进去的方法: function loopPushObj(oldArr) { let arr=[]; if(oldArr&&oldArr.length>0) { for(var i in oldArr) { var tempobj = {}; tempobj = oldArr[i]; tempobj['sex

自定义视图一:扩展现有的视图,添加新的XML属性

这个系列是老外写的,干货!翻译出来一起学习.如有不妥,不吝赐教! 简介 这个系列详细的介绍了如何穿件Android自定义视图.主要涉及的内容有如何绘制内容,layout和measure的原理,如何继承实现view group以及如何给其子视图添加动画.第一篇主要讲述如何扩展和使用现有的视图,以及如何添加特有的XML属性. 特定的任务使用特定的视图 Android提供的view都是比较通用的,哪里都可以用.但是在开发应用的过程中需要对这些通用的view加以修改.很多时候这些代码都添加到了Activ

JS如何向一个对象数组里面添加新的属性

向一个对象数组里面添加新的属性var arry= [{a:11,b:22,c:33,d:44},{a:11,b:0,c:0,d:44},{a:11,b:22,c:99,d:99}];var arry2=[];arry.map(((item, index)=> { arry2.push(Object.assign({},item,{mess1:item.c,mess2:item.d}))}))console.log(arry2); 将一个对象数组数据拿出来变成另一个对象var arry= [{a: