当前位置:网站首页>页面刷新没有执行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是否成功执行、是否阻塞执行
边栏推荐
- 7.16 Day22---MYSQL (Dao mode encapsulates JDBC)
- 想低成本保障软件安全?5大安全任务值得考虑
- Code Refactoring: For Unit Testing
- OpenSSF 安全计划:SBOM 将驱动软件供应链安全
- Can 't connect to MySQL server on' localhost3306 '(10061) simple solutions
- FFmpeg源码分析:avformat_open_input
- 8、自定义映射resultMap
- 心余力绌:企业面临的软件供应链安全困境
- Resolved error: npm WARN config global `--global`, `--local` are deprecated
- OpenRefine中的正则表达式
猜你喜欢
Can 't connect to MySQL server on' localhost3306 '(10061) simple solutions
webrtc中视频采集实现分析(一) 采集及图像处理接口封装
在被面试官说了无数次后,终于潜下心来整理了一下JVM的类加载器
CentOS7 - yum install mysql
字节最爱问的智力题,你会几道?
MySQL database (basic)
EntityComponentSystemSamples学习笔记
The cost of automated testing is high and the effect is poor, so what is the significance of automated testing?
Resolved error: npm WARN config global `--global`, `--local` are deprecated
程序员也应了解的Unity粒子系统
随机推荐
力扣:509. 斐波那契数
Unity自动生成阻挡Collider的GameObject工具
利用Jenkins实现Unity自动化构建
MediaCodec支持的类型
Unity表格配置编辑工具
Swoole学习(二)
OpenCV获取和设置图像的平均亮度
7.18 Day23 - the markup language
Linux环境下redis的下载、安装和启动(建议收藏)
7.13 Day20----MYSQL
FFmpeg源码分析:avformat_open_input
MySQL log articles, binlog log of MySQL log, detailed explanation of binlog log
7. Execution of special SQL
Cannot read properties of null (reading 'insertBefore')
Oracle备份脚本
DP4398:国产兼容替代CS4398立体声24位/192kHz音频解码芯片
EventBus源码分析
通过&修改数组中的值
sql server如何得到本条记录与上一条记录的差异,即变动值
Unity行为树AI分享