vue使用路由的query配置项时如何清除地址栏的参数
但这又会产生一个问题,如果是移动端项目还好,如果是pc端项目,当用户点击浏览器的返回箭头时,又回先显示。当触发popState事件时,跳转到原来的movies页面,问题解决。解决方式二:跳转路由路径时query参数没带过去,所以被清除了。把Movies.vue的参数传到Cinemas.vue。解决方式一:清空query的值。写vue项目时,如果想通过。路由的query配置项。
·
写vue项目时,如果想通过路由的query配置项把参数从一个组件传到另一个组件,但是又不希望?id=xxx显示在地址栏(如:http://localhost:8080/test?id=xxx的?id=xxx),该怎么做:
举一个案例:
把Movies.vue的hello参数传到Cinemas.vue
在Movies.vue写:
this.$router.push({
name: 'cinemas',
query: {
hello: 'vue'
}
})
在Cinemas.vue写:
解决方案一:清空query的值
created() {
console.log("this.$route--->", this.$route);
// 方式一:清空query的值
this.$router.push({ query: {} });
}
解决方案二:跳转路由时不带query参数
created() {
console.log("this.$route--->", this.$route);
// 方式二:跳转路由时不带query参数
this.$router.push(this.$route.path);
}
最终页面效果如下所示。可以看到,路径没有显示成http://localhost:8080/cinemas?hello=vue,而是显示成http://localhost:8080/cinemas,这就是我们要的效果。
更多推荐
已为社区贡献3条内容
所有评论(0)