Vue单页SPA后台管理点击刷新当前页面
栏目: JavaScript · 发布时间: 6年前
内容简介: 使用vue都知道 SPA页面中跳转当前页面是不会有反应的,例如 在login页面使用需求: 点击左侧菜单的当前导航页面属性我们看一下Vue-router的文档
使用vue都知道 SPA页面中跳转当前页面是不会有反应的,例如 在login页面使用 this.$router.push('login') ,页面是不会出现任何现象的,push的路由也不会进入你是记录,那么我们如何实现在单页应用的刷新呢?
需求: 点击左侧菜单的当前导航页面属性
我们看一下Vue-router的文档
router.push() // 添加一个新的记录 router.replace() // 不会向 history 添加新记录 router.go(n) //向前或者后退多少步 复制代码
很显然没刷新当前页面的api,这个问题,已经有大佬进行了解决,就是 TagsView ,有兴趣的可以看看实现方法
参考的大佬的思路.在左侧菜单导航栏上面也实现了点击刷新当前页面
思路
很明显,单页应用不存在自己跳转到自己的api,所以我们需要借助中间页面进行跳转
- 创建一个中间页面
redirect - 刷新自己不应该添加到浏览记录里面,所以使用
router.replace(),并携带当前页面的路由路径 - 在中间页面的
created函数中获取携带的参数路由路径,并进行再次router.replace()完成当前页面的刷新
因为这里使用的 vue-admin-template ,所以需要对侧边栏进行一些修改
src\views\layout\components\Sidebar\SidebarItem.vue
<template>
// ....
<app-link :to="resolvePath(onlyOneChild.path)">
<el-menu-item
:index="resolvePath(onlyOneChild.path)"
:class="{ 'submenu-title-noDropdown': !isNest }"
@click="reload(item)" // 添加点击方法
>
<item :meta="Object.assign({}, item.meta, onlyOneChild.meta)" />
</el-menu-item>
</app-link>
</template>
// ....
</template>
<script>
export default {
methods: {
// ...
// 点击重载
reload(item) {
// 如果发现当前路由与点击的路由一致就携带路由路径跳转到redirect页面
if (this.$route.name === item.name) {
this.$nextTick(() => {
// params 默认会解析成为path字段,如果使用参数的形式 / 会来解析成为%
this.$router.replace({
path: '/redirect' + this.$route.fullPath,
})
})
}
}
}}
</script>
复制代码
创建中转页面
src\views\redirect\index.vue
<script>
export default {
created() {
console.log(this.$route);
const { params, query } = this.$route
const { path } = params
this.$router.replace({ path: '/' + path, query })
},
render: function (h) {
return h() // avoid warning message
}
}
</script>
复制代码
配置路由
{
path: '/redirect',
component: Layout,
name: 'redirect',
hidden: true,
children: [
{
path: '/redirect/:path*', // path为默认名称 通配符*必须存在 反之404
component: () => import('@/views/redirect/index')
}
]
}
复制代码
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Swift iOS : 上拉刷新或者下拉刷新
- Swift iOS : 上拉刷新或者下拉刷新
- 优雅地刷新RecyclerView
- 上拉加载 下拉刷新
- jQuery ajax局部刷新
- vue项目刷新当前页
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
JavaScript征途
朱印宏 / 电子工业出版社 / 2009-9 / 89.00元
《JavaScript征途》是一本学习JavaScript语言的权威书籍,在遵循语言学习的特殊规律基础上精心选材,力争做到统筹、有序,在结构上体现系统性和完整性。同时还重点挖掘JavaScript基于对象的开发精髓及函数式编程两个技术核心。《JavaScript征途》内容全面,由浅入深,包括6篇21章,主要内容包括:JavaScript语言的基本特性,开发简单的JavaScript程序,JavaS......一起来看看 《JavaScript征途》 这本书的介绍吧!