当前位置:网站首页>页面刷新没有执行watch?
页面刷新没有执行watch?
2022-08-04 05:26:00 【愿为浪漫渡此劫】
页面刷新没有执行watch,怎么办?
在实际开发中,页面之间跳转后,会伴随着后端接口的调用,从而获取接口数据,更新跳转后的页面
前言
一般的,我们会把后端接口的调用时机,放在created()钩子里,但是针对跳转到另一个页面后,接口的调用时机还会在created()里面吗?
企业项目开发场景
- 要求:从A页面,跳转到B页面后,需要立即调用B页面的接口,更新页面数据
需求实现一、
将请求放在created()里面,
created() {
// API请求
}
注意:此时跳转后的页面不会自动调用接口,需要手动刷新浏览器才能调用接口
需求实现二、
监听路由跳转变化,根据路由变化,调用接口
watch:{
$route(to,from){
// 路由变化了,
// 调用接口
}
},
注意:此时跳转后的页面会立即调用接口,更新新页面数据,但是,用户刷新页面后,路由监听是不执行的,所有不再调用接口,页面数据丢失
需求实现三
1、监听路由跳转变化,根据路由变化,调用接口
2、同时,在created()调用后端接口
watch:{
$route(to,from){
// 路由变化了,
// 调用接口
}
},
// 避免用户刷新 造成数据丢失
created() {
// API请求
}
注意:此时跳转后的页面会立即调用接口,更新了新页面数据,同时用户刷新页面,也会调用接口,但是,路由变化的同时也是页面初次渲染,所以created和watch都会执行,造成接口重复调用
需求实现四
1、监听路由跳转变化,根据路由变化,调用接口
2、同时,在mounted()调用后端接口,此时页面已经渲染完成
watch:{
$route(to,from){
// 路由变化了,
// 调用接口
}
},
mounted() {
// API请求
}
此时,路径变化,立即调用一次接口,且用户刷新也会调用接口。缺点是:代码冗余,不好维护,可读性差
需求实现四
使用深度监听路由,immediate:true(页面初始化/刷新 立即执行)
watch:{
$route : {
handler(to,from) {
let programName = to.params.programName;
if(!programName) {
return
}else {
this.getArticleListApi(programName,{
programId : to.params.programId
})
}
},
immediate:true, // 页面初始化/刷新 立即执行
}
},
总结:路由造成数据丢失的有多种,最常见的就是浏览器刷新,数据丢失,如果是Vuex造成的,可以借助浏览器本地存储,不过个人推荐使用vuex-persistedstate插件,如果是其他造成的数据丢失,就需要定位到组件,具体问题具体分析了。核心就是:组件钩子函数和watch是否成功执行、是否阻塞执行
边栏推荐
猜你喜欢

MySQL log articles, binlog log of MySQL log, detailed explanation of binlog log

Programming hodgepodge (4)

Unity表格配置编辑工具
![Embedded system driver primary [3] - _IO model in character device driver foundation](/img/c7/21fc0651964a6a435e8ec5743b7662.png)
Embedded system driver primary [3] - _IO model in character device driver foundation

部署LVS-DR群集【实验】

7.18 Day23 - the markup language

word 公式编辑器 键入技巧 | 写数学作业必备速查表

Web Basics and Exercises for C1 Certification - My Study Notes

TSF微服务治理实战系列(一)——治理蓝图

Programming hodgepodge (3)
随机推荐
MediaCodec支持的类型
4.3 基于注解的声明式事务和基于XML的声明式事务
渗透测试(PenTest)基础指南
Unity开发类似Profile那样的数据分析工具
OpenRefine中的正则表达式
《看见新力量》第四期免费下载!走进十五位科技创业者的精彩故事
Tactile intelligent sharing - SSD20X realizes upgrade display progress bar
Plus版SBOM:流水线物料清单PBOM
去重的几种方式
MySQL日期函数
Typora 使用保姆级教程 | 看这一篇就够了 | 历史版本已被禁用
warning C4251: “std::vector<_Ty>”需要有 dll 接口由 class“Test”的客户端使用错误
嵌入式系统驱动初级【4】——字符设备驱动基础下_并发控制
C language -- operator details
PHP解决字符乱码问题(多种编码转换)
12、分页插件
9、动态SQL
关于C#的反射,你真的运用自如嘛?
sql server如何得到本条记录与上一条记录的差异,即变动值
力扣:509. 斐波那契数