vue 改变数据后,数据变化页面不刷新

在这里插入图片描述


导文

在vue项目中,会遇到修改完数据,但是视图却没有更新的情况
vue 改变数据后,数据变化页面不刷新
vue 改变数据后,需要滑动页面,数据才更新
vue中表格数据已改变,页面却未更新数据

文章重点

方法一:使用this.$forceUpdate()强制刷新

使用方法:直接调用即可,或者放到html里面使用

直接调用:

 this.list.forEach((item)=>{
...
})
console.log(this.list,'this.list')
this.$forceUpdate()

放到html里面使用:

<el-select v-model="..." @change="$forceUpdate()" placeholder="请选择">
...
</el-select>

方法二:Vue.set(object, key, value)

使用方法:

add() {
  this.$set(this.obj, 'name', '张三')
}

方法三:this.$nextTick

this.$nextTick 将回调延迟到下次DOM更新循环之后执行。在修改数据之后立即使用它,然后等待DOM更新。

this.$nextTick 跟全局方法 vue.nextTick 一样,不同的是,回调的 this 自动绑定到调用它的实例上。
使用方法:

 this.$nextTick(() => {
  this.handerErrors()
})

方法四:$set方法

使用方法:

//原代码
this.list.a=1
//使用set方法
this.$set(this.list,'a',1)
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue的路由切换页面刷新是由于Vue采用了单页应用(Single Page Application, SPA)的开发模式。单页应用是指只有一个HTML页面的应用,通过动态的改变页面的内容来实现不同的页面展示效果,而不是每次刷新整个页面。 在传统的多页应用中,每次页面切换都会发起一个新的http请求,然后服务器返回一个完整的HTML页面页面刷新就是浏览器通过加载新的HTML页面来实现的。 而在Vue的单页应用中,浏览器在加载页面时会先加载一个index.html文件,然后通过使用Vue的路由机制,在不刷新页面的情况下改变URL路径,并借助Vue的内部机制来动态更新页面内容。这意味着整个页面只有一个HTML文件,所有的数据交互和页面变化都通过JavaScript来完成。 因此,当Vue的路由切换时,页面刷新的原因是因为只是改变了URL路径,并没有重新加载整个页面Vue使用了虚拟DOM(Virtual DOM)的概念,在切换路由时,通过监测数据改变,重新构建虚拟DOM,并与原始的虚拟DOM进行插入、删除、更新等操作,从而只更新需要变化的部分,提高了页面的性能和体验。 这样的设计模式可以带来许多好处,如减少网络请求、提高页面加载速度、提升用户体验等。但也需要注意,在一些特殊情况下,比如页面切换后需要重新加载数据,我们需要手动控制页面刷新

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奶糖 肥晨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值