一、标签跳转: 映射路由
1、不带参数跳转
<template><!-- 在Vue中的<router-link>标签中,到页面最终还是转为<a>标签 --><router-link to="/about"><button>打开关于我们 - 不带参数1</button></router-link><router-link :to="{path: '/about'}"><button>打开关于我们 - 不带参数2</button></router-link></template><p><strong> </strong></p>
2、带参数跳转
<!-- home页面(首页) --><template><router-link :to="{path: '/about', query: {id: 1024, name:'mupiao', age: 28 }}"><button>打开关于我们 - 带参数1</button></router-link><router-link :to="{name: 'about', params: {id: 1024, name:'mupiao', age: 28 }}"><button>打开关于我们 - 带参数2</button></router-link></template>
3、接收参数
// about页面(关于我们)<template><section>关于我们</section></template><script>export default {name: "about",data() {return {};},created() {// 在Vue实例被创建之后的钩子函数中,接收home页面传过来的参数// 以query方式接收参数:【query传递数据是通过URL传递的,类似ajax中的get方式】console.log(this.$route.query.id); // 1014console.log(this.$route.query.name); // mupiaoconsole.log(this.$route.query.age); // 28// 以params方式接收参数:【params方式,类似ajax中的post方式】console.log(this.$route.params.id); // 1014console.log(this.$route.params.name); // mupiaoconsole.log(this.$route.params.age); // 28}}
二、编程式路由跳转: this.$router.push()
注意:和name配对的是params,和path配对的是query
localStorage — 是永久存储在本地,除非你主动去删除;
sessionStorage — 是存储到当前页面关闭为止,和其他tab页没关联;
1.命名路由搭配params,刷新页面参数会丢失(参数存在sessionStorage和localStorage中或使用查询参数搭配query)
2.查询参数搭配query,刷新页面数据不会丢失
1、不带参数跳转
<!-- home页面(首页) --><template><router-link :to="{path: 'about'}"><button>打开关于我们</button></router-link><button @click="open">打开关于我们</button></template><script>export default {name: "home",data() {return {};},methods: {open() {this.$router.push('/about');}},}</script>
2、带参数跳转
<!-- home页面(首页) --><template><router-link :to="{path: 'about'}"><button>打开关于我们</button></router-link><button @click="open1">打开关于我们 - query方式</button><button @click="open2">打开关于我们 - params方式</button></template><script>export default {name: "home",data() {return {};},methods: {// query方式(参数显示在路径上,刷新不会丢失)open1() {this.$router.push({path: '/about',query: {id: 2048,book: "了不起的Node.js",job: "Web前端"}});},//⚠️注:如果要传递的参数很长时,请问params方式,因为query方式是通过URL传递的,而URL传参数长度是有限制的哦!!// params方式(参数不显示在路径上,刷新会丢失)open2() {this.$router.push({name: "about", // ⚠️注:这里不能用path路径,只能用name【请对照router.js中的路由规则中的name项】,否则取不到传过去的数据params: {id: 2048,book: "了不起的Node.js",job: "Web前端"}});}},}</script>
3、接收参数
// about页面(关于我们)<template><section>关于我们</section></template><script>export default {name: "about",data() {return {};},created() {// 在Vue实例被创建之后的钩子函数中,接收home页面传过来的参数//⚠️注:在传递参数时,用什么方式传参,就用什么方式接收!!// 以query方式接收参数:【query传递数据是通过URL传递的,类似ajax中的get方式】console.log(this.$route.query.id); // 2048console.log(this.$route.query.book); // 了不起的Node.jsconsole.log(this.$route.query.job); // Web前端// 以params方式接收参数:【params方式,类似ajax中的post方式】console.log(this.$route.params.id); // 2048console.log(this.$route.params.book); // 了不起的Node.jsconsole.log(this.$route.params.job); // Web前端// this.$route 路由信息对象console.log(this.$route); //this.$route 对象中包涵了路由的相关信息,请自看!!</script>
真正的页面跳转:
一、HTML超链接跳转:跳转链接
//打开外部链接<a target="_blank" href="https://www.baidu.com/s?wd=Vue">百度一下 Vue</a>
二、浏览器BOM中的location.href跳转:
//在当前页面打开URL页面window.location.href = "https://www.baidu.com/s?wd=Vue";
三、浏览器BOM中的window.open()跳转:
//打开一个新的浏览器窗口window.open("https://www.baidu.com/s?wd=Vue", "_blank", "width=1000, height=500", true);
解决刷新页面数据丢失问题及退出登录清空数据
在APP.vue中加入如下代码,目的是将vuex里的信息保存到sessionStorage里
//任何页面F5刷新都会执行APP.vue中的生命周期函数//说明:登录登路由为/logincreated () {//判断当前路由是否是登录路由,//如果不是,则认为是在非登录界面刷新,将store中的数据保存到sessionStorage中if(this.$router.currentRoute.path != "/login"){//在页面加载时读取sessionStorage里的状态信息if (sessionStorage.getItem("store") ) {this.$store.replaceState(Object.assign({}, this.$store.state,JSON.parse(sessionStorage.getItem("store"))))}//在页面刷新时将vuex里的信息保存到sessionStorage里window.addEventListener("beforeunload",()=>{sessionStorage.setItem("store",JSON.stringify(this.$store.state))})}else{//否则清空sessionStorage中的数据sessionStorage.clear()}}
值得注意的一点是:
项目中的所有跳转至登录路由时,
不能使用this.$router.push(’/login’)
这种方式跳转,原因是这种方式不会触发APP.vue中的created函数,所以无法清空sessionStorage中的store数据;
window.location.replace(“/login”)
这种方式;跳转至登录路由时会触发APP.vue中的created函数,达到清空sessionStorage中的store数据的效果
