Vue.set 向响应式对象中添加响应式属性,及设置数组元素触发视图更新

一、为什么需要使用Vue.set?

  vue中不能检测到数组和对象的两种变化:

  1、数组长度的变化 vm.arr.length = 4

  2、数组通过索引值修改内容 vm.arr[1] = ‘aa’

  Vue.$set(target,key,value):可以动态的给数组、对象添加和修改数据,并更新视图中数据的显示。

  vue在构造函数new Vue()时,就通过Object.defineProperty中的getter和setter 这两个方法,完成了对数据的绑定。所以直接通过vm.arr[1] = ‘aa’的方法,无法修改值去触发vue中视图的更新,必须还得通过Object.defineProperty的方法去改变,而Vue.$set()就封装了js底层的Object.defineProperty方法。

  所以我们需要利用Vue.set() 响应式新增与修改数据。

二、Vue.set使用

  Vue不能检测到对象属性的添加或删除。

  由于Vue会在初始化实例时对属性执行getter/setter转化过程,所以属性必须在data对象上存在才能让Vue转换它,这样才能是响应式的。例如:

data () {
    return {
        form: {
            total: 10
        }
    }
}

// this.form.total是响应式的

// 若直接增加属性,是非响应式的
this.form.showFlag= true  //非响应式的

  使用Vue.set(object, key, value)方法将响应属性添加到嵌套的对象上。Vue.set(this.form, ‘showFlag‘, true)

  还可以使用vm.$set实例方法,这也是全局Vue.set方法的别名:this.$set(this.form, ‘showFlag‘, true)

  这样,this.form.showFlag 就是响应式的了。

  Vue.set(target, key/index, value) 向响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新。它必须用于向响应式对象上添加新属性,因为 Vue 无法探测普通的新增属性 (比如 this.obj.newProperty = ‘hi‘)

  官方文档:https://cn.vuejs.org/v2/api/#Vue-set

Vue.set( target, propertyName/index, value )

  • 参数

    • {Object | Array} target
    • {string | number} propertyName/index
    • {any} value
  • 返回值:设置的值。
  • 用法

    向响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新。它必须用于向响应式对象上添加新属性,因为 Vue 无法探测普通的新增属性 (比如 this.myObject.newProperty = ‘hi‘)

    注意对象不能是 Vue 实例,或者 Vue 实例的根数据对象。意思是,set 这个方法只能用于data 里面的子数组对象,而不能直接用于data (这个根数据)或者vue 实例

var vm = new Vue({
el:"#div",
  data: {
    items: [‘a‘, ‘b‘, ‘c‘]
  }
});

Vue.set(vm.items,2,"ling")

  设置数组元素:Vue.set(vm.items, 2, "ling") 表示把 vm.items  这个数组的下标为2 的元素,改为"ling",把数组  ["a","b","c"] 修改后是 ["a","b","ling"]

原文地址:https://www.cnblogs.com/goloving/p/10986120.html

时间: 2024-10-13 02:12:46

Vue.set 向响应式对象中添加响应式属性,及设置数组元素触发视图更新的相关文章

内置对象Array的原型对象中添加方法

// //倒序字符串的方法String.prototype.myReverse=function () { for(var i=this.length-1;i>=0;i--){ console.log(this[i]); }};var str="1234567";str.myReverse(); //为内置对象Array的原型对象中添加方法Array.prototype.mySort=function () { for(var i=0;i<this.length-1;i++

vue数组对象修改触发视图更新

直接修改数组元素是无法触发视图更新的,如 this.array[0] = { name: 'meng', age: 22 } 修改array的length也无法触发视图更新,如 this.array.length = 2; 触发视图更新的方法有如下几种 1. Vue.set 可以设置对象或数组的值,通过key或数组索引,可以触发视图更新 数组修改 Vue.set(array, indexOfItem, newValue) this.array.$set(indexOfItem, newValue

在linux中添加ftp用户,并设置相应的权限

在linux中添加ftp用户,并设置相应的权限,操作步骤如下: 1.环境:ftp为vsftp.被限制用户名为test.被限制路径为/home/test 2.建用户:在root用户下: useradd -d /home/test test //增加用户test,并制定test用户的主目录为/home/testpasswd test //为test设置密码 3.更改用户相应的权限设置: usermod -s /sbin/nologin test //限定用户test不能telnet,只能ftpuse

在vim中添加新的编程语言高亮设置

最近在看<7周7语言>这本书. 作为对各种语言的一次概览,本书的讲解十分吸引人. 本人现在使用的是虚拟机上运行的ubundu12.04.4,vim的版本是7.3 根据网上的查询,使用命令:echo $VIM 得到的是空. 于是改使用find命令,在 /usr/share/vim下找到了vim的全部文件. Io语言的vim语法高亮配置文件下载自http://www.vim.org/scripts/script.php?script_id=2116 Io programming language

使用jQuery匹配文档中所有的li元素,返回一个jQuery对象,然后通过数组下标的方式读取jQuery集合中第1个DOM元素,此时返回的是DOM对象,然后调用DOM属性innerHTML,读取该元素 包含的文本信息

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"><head> <meta htt

JavaScript 判断对象中是否有某属性

因为后端返回一个对象后,这个对象经常会出现缺少属性的情况 一个解决方法就是接受到数据后判断对象中是否有该属性,无的话加上属性和默认值 那么如何判断是否有该属性呢: test.hasOwnProperty('name') //true 自身属性 test.hasOwnProperty('age') //false 不存在 test.hasOwnProperty('toString') //false 原型链上属性 使用hasOwnProperty()就很容易知道了. 原文地址:https://ww

(一)数组或对象中最会一个属性是否该加逗号的测试

1.结论:在IE8中有兼容问题.会将逗号后面的空也算作一个属性,所以最后一个属性末不要加逗号 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> </body> <script src="lib

python中利用少量代码快速实现从类对象中抽取所需属性的一种实践

项目中有可能会碰到这样一种场景: 根据一个id,查询得到和id对应的完整数据信息存储对象,比如书籍id到书籍详细信息,用户id到用户详细信息等,详细信息字段可能包括几十甚至上百个数据字段,真正需要返回给调用方的字段实际上却只占其中一小部分,这是出于性能和带宽的考虑(甚至在有些场景中,处于隐私或者安全考虑,强制要求不能返回非协议定义的信息字段,比如第三方登录一般只返回用户昵称.性别等少量信息),一般会从详细的数据对象中抽取出所需要的信息组装一个新的简化对象. 今天碰到这样一个问题,需要将一个存储多

javascript,检测对象中是否存在某个属性

检测对象中属性的存在与否可以通过几种方法来判断. 1.使用in关键字. 该方法可以判断对象的自有属性和继承来的属性是否存在. var o={x:1}; "x" in o; //true,自有属性存在 "y" in o; //false "toString" in o; //true,是一个继承属性 2.使用对象的hasOwnProperty()方法. 该方法只能判断自有属性是否存在,对于继承属性会返回false. var o={x:1}; o.h