一、Vue的Set方法有什么用

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

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

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

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

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

图片来源自:Vue中文官网

三、在组件中使用Vue.set

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

<script>
	import Vue from 'vue'                                   //引用Vue
	export default{
		data(){
			return{
				data:['快乐','悲伤','理解']
			}
		},
		methods:{
			useSet(){
				this.data[1] = '前端喵'	        //视图层不会更新
				Vue.set(data,1,'前端喵');	//视图层成功更新
			}
		}
	}
</script>

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

<script>
	export default{
		data(){
			return{
				data:['快乐','悲伤','理解']
			}
		},
		methods:{
			useSet(){
				this.data[1] = '前端喵'	        //视图层不会更新
				this.$set(data,1,'前端喵');	//视图层成功更新
			}
		}
	}
</script>

四、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','可爱')