vue中如何解决页面刷新之后vuex中的数据消失问题以及vue-router如何传递参数

文末

如果30岁以前,可以还不知道自己想去做什么的话,那30岁之后,真的觉得时间非常的宝贵,不能再浪费时间在一些碎片化的事情上,比如说看综艺,电视剧。一个人的黄金时间也就二,三十年,不能过得浑浑噩噩。所以花了基本上休息的时间,去不断的完善自己的知识体系,希望可以成为一个领域内的TOP。

同样是干到30岁,普通人写业务代码划水,榜样们深度学习拓宽视野晋升管理。

这也是为什么大家都说30岁是程序员的门槛,很多人迈不过去,其实各行各业都是这样都会有个坎,公司永远都缺的高级人才,只用这样才能在大风大浪过后,依然闪耀不被公司淘汰不被社会淘汰。

269页《前端大厂面试宝典》

包含了腾讯、字节跳动、小米、阿里、滴滴、美团、58、拼多多、360、新浪、搜狐等一线互联网公司面试被问到的题目,涵盖了初中级前端技术点。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

前端面试题汇总

JavaScript

分析:考察的是如何将vuex数据进行本地持久化

解析:

-由于vuex中的数据是存于内存中的,页面刷新重置会导致数据归零,也就是所谓的消失。将数据本地持久化可以解决这个问题

  • 数据本地持久化所用到的技术是本地存储sessionStorage或者localStorage

  • 两者之间的差异是存储期限不一样,sessionStorage当关闭浏览器时数据也随之小时。而localStorage时永久保存在本地

实施方案:

  • state的持久化,也就是分别需要在state数据初始化/更新的时候进行读取和设置本地的存储操作

代码如下:

ecport default new Vuex.store({

state:{

uesr:localStorage.getItem(‘user’);//这时初始化时读取数据,并将数据存储在本地

},

mutations:{

updateUser(state,payload){

state.user=payload.user;

localStorage.setItem(‘user’,payload.user)//数据更新时,设置本地数据

}

}

})

2.vue-router传参


分析:考察vue-router的传值方式

解析:

vue-router传值可以通过地址传值

最简单的就是url,url传值又有两种形式,params和query参数传值

1)params传值,值得时动态路由传值

在路由配置中定义路由:{path:‘user/:id '}

最后

四轮技术面+一轮hr面结束,学习到了不少,面试也是一个学习检测自己的过程,面试前大概复习了 一周的时间,把以前的代码看了一下,字节跳动比较注重算法,面试前刷了下leetcode和剑指offer, 也刷了些在牛客网上的面经。大概就说这些了,写代码去了~

祝大家都能收获大厂offer~

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

篇幅有限,仅展示部分内容

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue Router使用params传参时,页面刷新参数丢失的问题可以通过以下几种方式来解决: 1. 使用query参数代替params参数:将参数传递给路由时,可以考虑使用query参数而不是params参数。query参数会以查询字符串的形式出现在URL刷新页面时参数不会丢失。例如,将参数传递给路由时,可以使用`this.$router.push({ path: '/example', query: { id: 123 } })`,然后在目标组件使用`this.$route.query.id`来获取参数值。 2. 使用localStorage或sessionStorage进行数据持久化:将参数保存在localStorage或sessionStorage,在组件加载时从存储获取参数值。这样即使页面刷新,参数仍然可以从存储恢复。例如,在路由导航守卫,可以将参数保存到localStorage:`localStorage.setItem('id', id)`,然后在组件加载时,从localStorage读取参数:`const id = localStorage.getItem('id')`。 3. 使用Vuex进行数据管理:将参数保存在Vuex的状态管理,在组件之间共享参数值。这样即使页面刷新,参数仍然可以从Vuex获取。例如,在某个组件将参数保存到Vuex的state:`this.$store.commit('saveId', id)`,然后在其他组件通过`this.$store.state.id`来获取参数值。 4. 使用路由解析函数:在Vue Router定义一个解析函数,用于从URL提取参数值,并在组件加载时调用该函数进行参数解析。这样即使页面刷新,解析函数仍然可以从URL提取参数值。具体实现可以参考Vue Router的官方文档的"Advanced Matching Patterns"一节。 以上是几种常见的解决方式,您可以根据具体需求选择适合的方法。希望对您有帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值