解决vue修改数据页面无效的问题

本文介绍了在Vue项目中如何为data中的对象动态添加属性,并保持视图的响应性。探讨了直接添加属性不可行的原因及两种解决方案:使用this.$set()方法和Object.assign()方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目开发的过程中,经常会遇到这种情况:为data中的某一个对象添加一个属性。
如下案例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
        <button @click="addAttribute()">添加属性方法</button>  
        <p>student属性显示在下面</p>
        <ul>
            <li v-for="item in student">{{item}}</li>
        </ul>
    </div>

    <script src="./js/vue.js"></script>
    <script>
        new Vue({
            el: '#app',
            data: {
                student: {
                    name: 'zdx'
                }
            },
            methods: {
                addAttribute() {   
                    this.student.age = 18;    //为student对象添加属性
                    console.log(this.student);
                }
            }
        })
    </script>
</body>
</html>

在这里插入图片描述
原因是由于受JavaScript的限制,vue.js不能监听对象属性的添加和删除,因为在vue组件初始化的过程中,会调用getter和setter方法,所以该属性必须是存在在data中,视图层才会响应该数据的变化,针对这个问题,有两种解决方案:

  1. this.$set(obj, key, value) 或 vue.set(obj, key, value)
methods: {
    addAttribute() {
        // this.student.age = 18;
        this.$set(this.student, 'age', 18);
        console.log(this.student);
    }
}
  1. Object.assign(target, sources)
 methods: {
      addAttribute() {
          // this.student.age = 18;
          // this.$set(this.student, 'age', 18);
          this.student.age = 18;
          this.student = Object.assign({}, this.student);
          console.log(this.student);
      }
  }

在这里插入图片描述

### IntelliJ IDEA 中 Vue 代码修改后未生效的解决方案 在开发过程中,如果发现修改 Vue 文件中的代码后,在浏览器中刷新页面并未看到效果,则可能是由于配置或缓存问题引起的。以下是可能的原因及其对应的解决方法: #### 配置 Tomcat 的自动重载功能 确保 `Tomcat` 的配置文件 `conf/context.xml` 已经设置了 `reloadable="true"` 属性[^1]。这一步可以使得容器检测到类路径下的变化并重新加载应用。 #### 修改运行配置 (Run/Debug Configurations) 对于 Spring Boot 或其他基于 Java 的项目,可以通过调整运行配置来实现热部署的功能。具体操作如下: - 打开 **Edit Configurations** 对话框。 - 在对应的应用程序配置项中勾选 **Update resources** 和 **Build project automatically** 选项[^2]。 #### 新版 IntelliJ IDEA 的资源更新设置 针对新版 IntelliJ IDEA 用户,可能存在界面布局的变化。通过以下方式启用即时生效功能: - 进入项目的运行配置菜单。 - 将红框标记的部分改为 **Update resources** 模式[^3]。 #### 清理缓存与强制刷新 有时浏览器端会保留旧版本的内容作为缓存数据。因此建议尝试清除浏览器缓存或者使用无痕模式访问网页以排除干扰因素。 #### 开启 Hot Module Replacement (HMR) 功能 如果是纯前端工程(如单独构建的 Vue.js 应用),则需确认 Webpack 是否已开启 HMR 支持。通常情况下,默认创建的 Vue CLI 脚手架已经集成了该特性;但如果手动定制过打包工具链,则需要显式声明相关插件和服务端监听逻辑。 ```javascript // webpack.config.js 示例片段 module.exports = { devServer: { hot: true, // 启动热替换服务 inline: true, }, }; ``` --- ####
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值