关于VUE中v-model响应式失效的问题
1.问题描述
在项目开发中遇到,在input标签使用v-model进行数据双向绑定,但最终发现页面偶尔会出现数据绑定不显示的问题,cosole发现数据确实已绑定上,针对此问题进行了逐项排查。
2.介绍
v-model
是 Vue.js 中用于实现双向数据绑定的指令。全指令写法为v-model:value="XXX",一般简写为v-model。
3.问题原因
阅读官方文档,官方给出的解释如下:
在某些情况下,直接修改对象或者数组的属性可能不会触发响应式更新。
错误示例:
methods: {
updateUser() {
// 错误的修改方式,可能不会触发响应式更新
// this.user.name = 'Jane';
}
}
推荐写法:使用$set内置函数给属性赋值
methods: {
updateUser() {
// 正确的修改方式
this.$set(this.user, 'name', 'Jane');
}
}
问题解决。在此记录。
4.扩展-其他原因
1. 数据未正确定义:即未在data里进行定义
2. 组件未正确接收 v-model:一般是自定义组件,要确保属性正确接收。
示例代码
<template>
<div>
<!-- 使用自定义组件并绑定 v-model -->
<CustomInput v-model="message" />
<!-- 显示 message 数据 -->
<p>{{ message }}</p>
</div>
</template>
<script>
import CustomInput from './CustomInput.vue';
export default {
components: {
CustomInput
},
data() {
return {
message: ''
};
}
};
</script>
<!-- CustomInput.vue -->
<template>
<input :value="modelValue" @input="$emit('update:modelValue', $event.target.value)" />
</template>
<script>
export default {
props: ['modelValue'],
emits: ['update:modelValue']
};
</script>
在这个示例中,CustomInput
组件正确接收了 modelValue
prop,并且在输入框输入内容时触发 update:modelValue
事件,从而实现了双向数据绑定。
3.Vue 实例未正确挂载:要确保Vue 实例已经正确挂载到 DOM 元素上
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Vue Example</title>
<!-- 引入 Vue.js -->
<script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
</head>
<body>
<div id="app">
<!-- 使用 v-model 绑定输入框和 message 数据 -->
<input v-model="message" />
<!-- 显示 message 数据 -->
<p>{{ message }}</p>
</div>
<script>
new Vue({
el: '#app',
data: {
message: ''
}
});
</script>
</body>
</html>
Vue 实例通过 el
选项正确挂载到了 id
为 app
的 DOM 元素上,这样 v-model
才能正常工作。