您的位置:首页 > 娱乐 > 明星 > 广西网站建设产品介绍_国外服务器租用价格_北京广告公司_怎么找到当地的微信推广

广西网站建设产品介绍_国外服务器租用价格_北京广告公司_怎么找到当地的微信推广

2025/1/8 14:16:47 来源:https://blog.csdn.net/weixin_44593999/article/details/142929673  浏览:    关键词:广西网站建设产品介绍_国外服务器租用价格_北京广告公司_怎么找到当地的微信推广
广西网站建设产品介绍_国外服务器租用价格_北京广告公司_怎么找到当地的微信推广

vue3 使用 Vue Router实现前端路由控制

**在现代Web应用中,前端路由控制是非常重要的一部分。它可以帮助我们将不同的页面内容展示给用户,同时保持用户在浏览不同页面时的连贯性。本文将介绍如何使用Vue Router来实现前端路由控制。
首先,我们需要安装Vue Router。在项目根目录下运行以下命令:
**

npm install vue-router@next

安装完成后,我们可以开始编写代码了。首先,我们需要导入createRoutercreateWebHistory函数,以及我们自定义的视图组件。

import HomeView from '../views/HomeView.vue'
import AdminView from '@/views/AdminView.vue'
import AboutView from '../views/AboutView.vue'
import ChildenList from '@/views/childenList.vue'

接下来,我们需要创建一个路由实例,并配置我们的路由规则。在这个例子中,我们有三个主页面:首页(HomeView)、关于页面(AboutView)和管理员页面(AdminView)。我们还定义了一个子路由(ChildenList),用于显示关于页面下的子页面。

const router = createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [{path: '/',name: 'home',component: HomeView},{path: '/about',name: 'about',children: [  {  path: 'ChildenList',  name: 'ChildenList',  component: ChildenList,  meta: { requiresAuth: true, role: 'admin' }}],//  component:AboutView,},{path: '/admin',name: 'admin',component:AdminView,meta: { requiresAuth: true, role: 'admin' }}]

为了实现权限控制,我们需要在路由守卫中添加一些逻辑。在每个路由规则中,我们可以添加一个meta属性来指定该路由是否需要认证以及对应的角色。在这个例子中,我们为/about/admin路由设置了requiresAuthrole属性

router.beforeEach((to, from, next) => {const user = "name" // 假设这是从localStorage获取用户信息的函数if (to.matched.some(record => record.meta.requiresAuth)) {// 这个路由需要权限if (!user || (to.meta.role && user !== to.meta.role)) {// 用户未登录或者角色不匹配next({ path: '/about'}) // 重定向到登录页面} else {// 用户已登录且角色匹配next()}} else {// 这个路由不需要权限next()}
})

最后将router导出

export default router

在main.js/main.ts引入
在这里插入图片描述
最后挂载routerView用于动态渲染与当前活跃路由匹配的组件
在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com