vue数据更新了但在页面上没有显示出来的解决方法

 更新时间:2023年12月17日 09:40:24   作者:UserGuan  
有时候 vue 无法监听到数据的变化,导致数据变化但是视图没有变化,也就是数据更新了,但在页面上没有显示出来,所以本文给出了三种解决方法,通过代码示例介绍的非常详细,需要的朋友可以参考下

方法一:使用 this.$set() 进行数据更新

this.$set(target, key, value);

target:要更改的数据源(可以是对象或者数组)

key:要更改的具体数据

value:重新赋的值

基本语法(对象):this.$set(要改变的对象,"要改变的对象属性","新值")

基本语法(数组):this.$set(要修改的数组,要修改的数组下标,{ "要修改的数组对象,一个/多个" })

例如:

定义数据

// 对象
obj: { name: "小明", age: 18 }
 
 
// 数组对象
arr: [{ name: "小王", age: 18 }, { name: "小张", age: 20 }]
// 普通数组
twoArr: [11, 22, 33]

修改数据

// 对象
this.$set(this.obj, "name", "小刘")
console.log(this.obj) // obj={ name: "小刘", age: 18 }
 
 
// 数组对象
this.$set(this.arr, 1, { name: "小王", age: 19 })
console.log(this.arr) // arr=[{ name: "小王", age: 18 }, { name: "小王", age: 19 }]
// 普通数组
this.$set(this.twoArr, 0, 99)
console.log(this.twoArr) // twoArr=[99, 22, 33]

新增数据

// 对象
this.$set(this.obj, "sex", "男")
console.log(this.obj) // obj={ name: "小明", age: 18, sex: "男" }
 
 
// 数组对象
const len = this.arr.length
this.$set(this.arr, len, { name: "小紫", age: 18 })
console.log(this.arr) // arr=[{ name: "小王", age: 18 }, { name: "小张", age: 20 }, { name: "小紫", age: 18 }]
// 普通数组
const len2 = this.twoArr.length
this.$set(this.twoArr, len2, 44)
console.log(this.twoArr) // twoArr=[11, 22, 33, 44]

方法二:使用 this.$forceUpdate() 进行强制更新

this.$forceUpdate() 强制更新方法,作用是触发 vue 的 update 方法

this.$forceUpdate(); // 强制更新
updateForm() {
    this.formData.name = "张三";
    this.$forceUpdate(); // 强制更新
},

方法三:更改引用,创建一个新的数组或对象,替换旧的数组或对象,强制更新视图

// 用于数组
this.recordList = [...this.recordList]
 
 
// 用于对象
this.recordObj = { ...this.recordObj }

在 el-table 表格中数据发生变化了,表格未重新渲染的问题

解决办法:

在 el-table 中添加一个 key 值,设置成 Boolean 类型,在数据更新后去更新这个 key 值

例子如下:

<el-table :key="refreshTable" :data="tableData" border>
  <el-table-column type="index" label="序号" width="120" align="center" />
  <el-table-column prop="userName" label="姓名" align="center" />
  <el-table-column label="操作" width="200" align="center">
    <template slot-scope="scope">
      <el-button type="text" @click="toUpdate(scope.row)">修改</el-button>
      <el-button type="text" @click="toDel(scope.row, scope.$index)">删除</el-button>
      <el-button type="text" @click="toDetail(scope.row)">详情</el-button>
    </template>
  </el-table-column>
</el-table>
refreshTable: false, // 表格数据刷新标志
this.refreshTable = !this.refreshTable // 重新渲染表格

在数据更新的后面加上 this.refreshTable = !this.refreshTable 即可

以上就是vue数据更新了但在页面上没有显示出来的解决方法的详细内容,更多关于vue数据更新但页面没有显示的资料请关注脚本之家其它相关文章!

相关文章

  • 一文详解如何在vue.config.js配置代码混淆加密、压缩

    一文详解如何在vue.config.js配置代码混淆加密、压缩

    这篇文章主要介绍了如何在vue.config.js配置代码混淆加密、压缩的相关资料,文中通过代码介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2025-05-05
  • vue3实现长列表虚拟滚动的示例代码

    vue3实现长列表虚拟滚动的示例代码

    本文主要介绍了vue3实现长列表虚拟滚动的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-01-01
  • VUE父组件异步获取数据,子组件接收的值为空的问题

    VUE父组件异步获取数据,子组件接收的值为空的问题

    这篇文章主要介绍了VUE父组件异步获取数据,子组件接收的值为空的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • vue 项目全屏插件screenfull使用案例

    vue 项目全屏插件screenfull使用案例

    这篇文章主要介绍了vue 项目全屏插件screenfull使用案例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-12-12
  • Vue3中列表拖拽排序的实现示例

    Vue3中列表拖拽排序的实现示例

    本文主要介绍了Vue3中列表拖拽排序的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • uniapp开发打包成H5部署到服务器的详细步骤

    uniapp开发打包成H5部署到服务器的详细步骤

    前端使用uniapp开发项目完成后,需要将页面打包,生成H5的静态文件,部署在服务器上这样通过服务器链接地址,直接可以在手机上点开来访问,下面小编给大家讲解uniapp开发打包成H5部署到服务器的步骤,感兴趣的朋友一起看看吧
    2022-11-11
  • vue中跨域以及sessionId不一致问题及解决

    vue中跨域以及sessionId不一致问题及解决

    这篇文章主要介绍了vue中跨域以及sessionId不一致问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • vue管理系统项目中的一些核心技能汇总

    vue管理系统项目中的一些核心技能汇总

    Vue是当今增长最快的前端框架,Vue 平易近人、用途广泛且性能卓越,它的语法非常直观,并且具有友好的学习曲线,是开发人员最想学习的顶级前端库之一,下面这篇文章主要给大家介绍了关于vue管理系统项目中的一些核心技能,需要的朋友可以参考下
    2022-05-05
  • VUE实现大转盘抽奖

    VUE实现大转盘抽奖

    营运三宝(九宫格、大转盘、老虎机,当然此三宝当然是最基础的营销运营手段),本片文章聊聊大转盘,转盘的实现逻辑应该是营销方案较为简单的一种了,本文将介绍如何实现大转盘抽奖,感兴趣的朋友可以参考下
    2021-05-05
  • 基于Vue3制作简单的消消乐游戏

    基于Vue3制作简单的消消乐游戏

    这篇文章主要为大家介绍了如何利用Vue3制作简单的消消乐游戏,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起动手试一试
    2022-05-05

最新评论