set修改对象 vue_Vue的set方法深入浅出

一、Vue的Set方法有什么用

在Vue中,对数组和对象的某些操作是无法进行数据层与视图层实时响应的,情况如下 :

默认数据:data = ['快乐','悲伤','理解']

1.当你利用索引直接设置一个项时,如:data[1] = '前端喵'

2.当你修改数组的长度时,如:data.length = 4

二、无法响应对象、数组的原因

图片来源自:Vue中文官网

三、在组件中使用Vue.set

1.我们通过Vue.set使用这一方法,但需要先引入Vue

import Vue from 'vue' //引用Vue

export default{

data(){

return{

data:['快乐','悲伤','理解']

}

},

methods:{

useSet(){

this.data[1] = '前端喵' //视图层不会更新

Vue.set(data,1,'前端喵');//视图层成功更新

}

}

}

2.Vue.set有一个别名: this.$set,通常我们在组件中不会引入Vue,而是会常常使用到this,这个方法也是我们经常使用的

export default{

data(){

return{

data:['快乐','悲伤','理解']

}

},

methods:{

useSet(){

this.data[1] = '前端喵' //视图层不会更新

this.$set(data,1,'前端喵');//视图层成功更新

}

}

}

四、Vue.set参数详解

数组:

data:['快乐','悲伤','理解']

Vue.set(array,key,value)

// array 代表 数组

// key 代表 键名

// value 代表 新的值

// 例子:

// 修改:Vue.set(data,1,'前端喵')

//     新增:Vue.set(data,5,'喜欢')

对象:

data:{

'color':'#fff',

'size':'500'

}

Vue.set(object,key,value)

// object 代表 对象

// key 代表  键名

// value 代表 新值

// 例子:

//     修改:Vue.set(data,'color','#000')

//     新增:Vue.set(data,'type','可爱')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值