解决vue修改数据绑定的视图不能动态更新的问题

14 篇文章 1 订阅

在写项目的时候遇见一个问题,修改vue v-bind或v-model绑定的数据时,视图不能更新

这就感觉很无语了。。。。当时在写一个弹窗,弹窗的数据更新后不能更新视图,需要重新刷新才行。

这样的问题简直不能忍受。。。。 多方查找,才发现 vue文档里有这样一句话。

Vue 无法检测 property 的添加或移除。由于 Vue 会在初始化实例时对 property 执行 getter/setter 转化,所以 property 必须在 data 对象上存在才能让 Vue 将它转换为响应式的。

这句话的意思就是说,vue是基于响应式的,在vue中定义(绑定)的对象或数组,在新增或删除属性时,vue并不能检测到这些变化,但可以检测到属性的修改,(因为是基于getter/setter的)所以,只有data对象上存在的属性才可以是响应式的,就是可以被更新的!

幸运的是,vue提供了一些解决方法。

就是使用Vue.set(object, propertyName, value)($set)方法设置新增的属性,使用this.$set()方法等价

例如:

data = {
    a: 1
}

// 为data对象新增一个b属性,值为2
Vue.set(data, 'b', 2)

其实方法参数已经写的很清楚了,第一个参数就是要新增的对象,第二个参数是新增的属性名,第三个参数是新增的属性值

对于数组更麻烦些,vue文档上写出:

Vue 不能检测以下数组的变动

  1. 当你利用索引直接设置一个数组项时,例如:vm.items[indexOfItem] = newValue
  2. 当你修改数组的长度时,例如:vm.items.length = newLength

也就是说在任何改动数组的值时,vue也不能检测到修改了!

为了解决第一类问题,以下两种方式都可以实现和 vm.items[indexOfItem] = newValue 相同的效果,同时也将在响应式系统内触发状态更新:

// Vue.set
Vue.set(vm.items, indexOfItem, newValue)
// Array.prototype.splice
vm.items.splice(indexOfItem, 1, newValue)

为了解决第二类问题,你可以使用 splice

vm.items.splice(newLength)

 

删除属性使用this.$delete(object, propertyName)

 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Vue数据绑定机制是Vue框架的核心特性之一,通过将数据视图进行关联,实现了数据的响应式更新,即当数据发生变化时,视图会自动更新。 具体来说,Vue数据绑定机制包括以下几个方面: 1. 模板语法:Vue的模板语法使用类似于HTML的标记语言,可以将Vue实例中的数据绑定到模板中。例如: ``` <template> <div> {{ message }} </div> </template> <script> export default { data() { return { message: 'Hello World' } } } </script> ``` 在上面的例子中,`{{ message }}`会被替换为`Hello World`,这是因为Vue将`message`属性绑定到了模板中。 2. 数据绑定Vue提供了多种数据绑定方式,包括单向绑定、双向绑定等。其中,双向绑定可以实现数据的自动更新。例如: ``` <template> <div> <input v-model="message" /> </div> </template> <script> export default { data() { return { message: 'Hello World' } } } </script> ``` 在上面的例子中,`<input v-model="message" />`会将用户输入的内容自动绑定到`message`属性上,当用户输入内容时,`message`属性会自动更新,从而触发视图更新。 3. 响应式更新Vue使用了一种响应式更新的机制,即当数据发生变化时,Vue会自动侦测到这些变化,并通知视图进行更新。例如: ``` <template> <div> <button @click="changeMessage">Change Message</button> <div> {{ message }} </div> </div> </template> <script> export default { data() { return { message: 'Hello World' } }, methods: { changeMessage() { this.message = 'Hello Vue'; } } } </script> ``` 在上面的例子中,当用户点击`Change Message`按钮时,`changeMessage`方法会修改`message`属性的值,Vue会自动侦测到这个变化,并通知视图进行更新。 总的来说,通过Vue数据绑定机制,我们可以将数据视图进行关联,实现数据的自动更新,从而提高开发效率,减少代码量。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值