当前位置: 首页 > news >正文

关于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');
    }
  }

问题解决。在此记录。

【补充】:this.$forceUpdate()实例方法

这个方法是一个实例方法,用于强制Vue实例重新渲染页面,手动触发更新。也可解决此问题。

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 才能正常工作。

相关文章:

  • Spring相关面试题总结
  • docker打包使用有头模式playwright
  • 【开题报告+论文+源码】基于springboot加vue 前后端分离的校园新闻审核发布管理系统
  • 鸿蒙NEXT小游戏开发:记忆翻牌
  • 网络攻防快速入门笔记pwn | 02 栈溢出题型 | 2.3 ret2syscall
  • 【C++进阶四】vector模拟实现
  • 蓝桥杯省模拟赛 数位和
  • 使用LangChain Agents构建Gradio及Gradio Tools(3)——使用Langchain agents构建Gradio UI
  • AI-人工智能-多模态学习助力精准预测心脏毒性
  • 使用Hugging Face训练自定义重排模型(Reranker)完全指南
  • 2024年蓝桥杯Java B组省赛真题超详解析-分布式队列
  • Docker中安装MySQL--------【详细图解】
  • Vue2函数式组件实战:手写可调用的动态组件,适用于toast轻提示、tip提示、dialog弹窗等
  • 掌握AI营销:移动营销的新动力
  • c++:哈希表
  • GPT-4o推出的原生图像生成功能升级后有点东西!
  • 世界通信大会、嵌入式展及慕尼黑上海光博会亮点回顾
  • 手绘风格流程图工具:简单高效的在线流程图绘制工具
  • C语言复习笔记--指针(1)
  • echarts+HTML 绘制3d地图,加载散点+散点点击事件
  • 玉渊谭天:美方多渠道主动接触中方希望谈关税
  • 拍摄《我们这一代》的肖全开展“江浙沪叙事”
  • 停电催生商机,中国品牌 “照亮” 西班牙
  • 北京亦庄启动青年人才创新创业生态示范区
  • 市场监管总局出手整治涉企乱收费,聚焦政府部门及下属单位等领域
  • 美国参议院投票通过戴维·珀杜出任美国驻华大使