当前位置: 首页 > wzjs >正文

小程序制作代码编写江西seo

小程序制作代码编写,江西seo,网站和网页的概念,全国前十名校程序开发公司要想实现vitevue-router实现动态路由我们需要用到 1. addRoute() 官方文档中addRoute的使用 当我们添加一个主路由的时候 router.addRoute({ path: /permission, name: permission, component: () > import(xxxxx)}) 添加子路由也就是嵌套路由 router.addRoute(主路由的…

要想实现vite+vue-router实现动态路由我们需要用到

1. addRoute()

官方文档中addRoute的使用

当我们添加一个主路由的时候

router.addRoute({ path: '/permission', name: 'permission', component: () => import('xxxxx')})

添加子路由也就是嵌套路由

router.addRoute('主路由的name', { path: 'settings', component: AdminSettings })

2. 导航守卫使用时的注意事项,否则会出现刷新白屏,或者路由访问死循环等

之前我们使用导航守卫的时候需要一个参数next()去控制是否放行以及去哪个页面,但是在新版本的vue-router里面可以不是用next()

我们可以新建一个permission.ts文件

import router from "./index";
import { useSessionStorage } from "@vueuse/core";
import { StorageEnum } from "@/enum";
import { useUserStore } from "@/store";const whiteList = ["/login", "/404"];router.beforeEach(async (to) => {const token = useSessionStorage(StorageEnum.TOKEN, "").value;// 如果在白名单里面 并且 token 不存在if (whiteList.includes(to.path) && !token) {return true;} else {const { menuList, getMenuList } = useUserStore();// 如果为空数组,name就请求接口重新获取后端维护的路由数据if (!menuList.length) {await getMenuList();console.log("获取全部路由 =>", router.getRoutes());// 触发重定向 不这样写会导致刷新找不到路由 两种写法都行// return { path: to.fullPath };return to.fullPath;}}
});

出现404的话比如说你在路由表中维护了下面路由映射

{path: "/:pathMatch(.*)",name: "page404",component: () => import("@/views/system/404.vue"),
}

3. 获取后端tree数据,递归循环,可能业务会有type类型,比如分为模块,菜单,页面,按钮等,到时候结合业务去实现逻辑

4.import.meta.glob()

import.meta.glob动态的去拼接获取文件,把后台返回内容转换成() => import('xxxx')格式

以下代码仅供参考,有很多需要完善的地方

import type { RouterType } from "@/router/type";
import router from "@/router";
import type { RouteRecordRaw } from "vue-router";export const useRouterConfig = () => {// 获取views目录下的所有的文件 不要使用@别名 const modules = import.meta.glob("../views/**");const asyncRoutes = ref<RouterType[]>([]);const addRoutes = (menus: RouterType[]) => {asyncRoutes.value = menus;filterAsyncRouter();// 动态添加 / 路由router.addRoute({path: "/",redirect: asyncRoutes.value[0].path,});};const filterAsyncRouter = () => {const routerLoop = (routes: RouterType[], ParentName?: string) => {routes.forEach((item) => {if (item.component === "Layout") {item.component = () => import("@/layout/index.vue");} else {item.component = resolveComponent(item.component);}const { title, show, icon, name, path, component, children } = item;const route: RouteRecordRaw = {component,path,name,meta: {title,show,icon,},children: children as any,};// 动态添加路由if (ParentName) {router.addRoute(ParentName, route);} else {router.addRoute(route);}if (item.children && item.children.length > 0) {routerLoop(item.children, item.name);}});};routerLoop(asyncRoutes.value);};const resolveComponent = (path: string) => {console.log(modules);// 拿到views下面的所有文件之后,动态拼接`key`去获取valueconst importPage = modules[`../views${path}`];if (!importPage) {throw new Error(`Unknown page ${path}. Is it located under Pages with a .vue extension?`);}return importPage;};return { addRoutes };
};

http://www.dtcms.com/wzjs/479880.html

相关文章:

  • 帝国cms论坛seo排名优化方式
  • 大众点评怎么做团购网站郑州手机网站建设
  • 大连网站推广公司百度官网首页下载
  • 网站换域名有没有影响吗站长工具app下载
  • 怎样建个人网站 步骤论坛推广的步骤
  • 上海信息公司做网站东莞seo收费
  • 自助建设wap网站十大培训机构教育培训机构哪家好
  • 南京门户网站建设优秀营销软文范例300字
  • 现在个人做网站还能盈利网站维护中
  • 学设计的网站推荐携程: 2023年旅行搜索上涨超900%
  • 网站修改文案百度服务热线
  • 淄博网站建设排行榜中文域名注册管理中心
  • 企业网站模板网页模板百度关键字优化精灵
  • 平台设计方案怎么做windows优化大师下载
  • 网站建设毕业设计个人总结应用关键词优化
  • wordpress插件选项seo综合查询站长工具关键词
  • 网站建设补充协议范本网站制作公司高端
  • 手机网站改版百度推广开户2400
  • 淘宝做网站给了钱seo引擎
  • 网络营销策划书8000字沧州网站推广优化
  • 美好乡村建设网站广州公关公司
  • 温州网站制作哪家好运营商大数据精准营销
  • 做saas平台网站厦门seo排名外包
  • 微信网站模块大连网站制作
  • cms适合做什么网站seo分析报告
  • 建设网站的网站首页正规电商培训班
  • 做订购网站深圳百度seo哪家好
  • 企业简介模板图片百度seo培训课程
  • 四川全美网络科技有限公司重庆seo是什么
  • 免费学做美食视频网站有哪些外贸网站平台哪个好