Vue怎么解决router传递params参数在页面刷新时数据丢失问题
本文小编为大家详细介绍“Vue怎么解决router传递params参数在页面刷新时数据丢失问题”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue怎么解决router传递params参数在页面刷新时数据丢失问题”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于网站设计制作、做网站、古城网络推广、小程序设计、古城网络营销、古城企业策划、古城品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供古城建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com
Vue 项目:如何解决 router 传递 params 参数,在页面刷新时数据丢失
情况是这样,通常我们会从一个 A 页面跳转到另一个 B 页面,如果这两个页面存在数据交互的话,就会有可能发生数据丢失的情况:
就比如我们 A 页面有一个按钮,点击按钮将数据传递给其他页面:
那接下来我们就可以新建一个 A.vue 文件代码如下:
export default {
name: 'A',
data() {
row: {
name: 'A 页面'
},
},
methods: {
toB() {
this.$router.push({
name: 'B',
params: {
row: this.row
}
})
}
}
}
接着就是 B 页面接受 A 页面的数据:
我们可以新建一个 B.vue 页面:
export default {
name: 'B',
props: ['row'],
}
这里之所以可以使用 props 属性来接收 row,是因为我们在路由配置文件通过设置 props 为 true 来开启了路由参数解耦:
{
path: '/B',
name: 'B',
props: true,
component: import('B.vue')
}
但是如果用户突然刷新了 B 页面数据会丢失,我们一般如何解决呢?大概有三种方法:
第一种:使用 query 查询的方式传递参数: 在 A 页面传递数据:
this.$router.push({
name: 'B',
query: {
row: JSON.stringify(this.row)
}
})
B 页面接受数据:
第二种:还是使用 params 传递参数,但是得结合 localstroage 缓存
比如 A 页面:
this.$router.push({
name: 'B',
params: {
row: this.row
}
})
B 页面接受数据: 在 created 生命周期时先缓存数据,在页面销毁时删除缓存
export default {
name: 'B',
data() {
return {
row: null
}
},
created() {
let rowData = localStorage.getItem('rowData')
if(rowData) {
this.row = this.$route.params.row
localStorage.setItem('rowData', JSON.stringify(this.$route.params.row))
}
},
beforeDestory() {
localStorage.removeItem('rowData')
}
}
读到这里,这篇“Vue怎么解决router传递params参数在页面刷新时数据丢失问题”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注创新互联行业资讯频道。
本文名称:Vue怎么解决router传递params参数在页面刷新时数据丢失问题
文章地址:http://hbruida.cn/article/joccph.html