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

金华网站建设方案报价百度自媒体怎么注册

金华网站建设方案报价,百度自媒体怎么注册,单页网站订单系统怎么改邮箱,毕业设计网页文章目录 前言定义项目页面格式一、vite 配置动态路由新建 /router/utils.ts引入 /router/utils.ts 二、webpack 配置动态路由总结如有启发,可点赞收藏哟~ 前言 项目中动态配置路由可以减少路由配置时间,并可减少配置路由出现的一些奇奇怪怪的问题 路由…

文章目录

  • 前言
  • 定义项目页面格式
  • 一、vite 配置动态路由
    • 新建 `/router/utils.ts`
    • 引入 `/router/utils.ts`
  • 二、webpack 配置动态路由
  • 总结
    • `如有启发,可点赞收藏哟~`


前言

项目中动态配置路由可以减少路由配置时间,并可减少配置路由出现的一些奇奇怪怪的问题
路由配置化可统一定义相关属性等
本文记录vitewebppack两种构建工具配置动态路由,


定义项目页面格式

页面定义最好同时定义对应的titlename

  • 以views目录的page-template为例

在这里插入图片描述

  • page-template/index.ts文件
import { defineComponent, h, defineAsyncComponent } from 'vue';const PageComponent = defineAsyncComponent(() => import('./components/index.vue'));export default defineComponent({// 配置后可在 动态获取路由配置中设置对应值title: '页面模版',name: 'PageTemplate',setup() {return () => h(PageComponent);},
});
  • page-template/components/index.ts文件
import { defineComponent } from 'vue'
export default defineComponent({setup() {return {};},
});
  • page-template/components/index.vue文件
<script lang="ts" src="./index.ts" /><template><div>template</div>
</template><style scoped lang="less"></style>

一、vite 配置动态路由

vite使用import.meta.glob动态获取文件

新建 /router/utils.ts

/*** 路由配置文件*/import { DEFAULT_DOCUMENT_TITLE } from '@/const/base';
import type { RouteRecordRaw } from 'vue-router';function getComponent() {return import.meta.glob('../views/**/index.ts', { eager: true });
}// 获取路由文件
export const vueRouters = (): RouteRecordRaw[] => {const routerList: RouteRecordRaw[] = [];const files = getComponent();Object.keys(files).forEach((fileSrc: string) => {const component = files[fileSrc] as any;const componentPath = fileSrc.replace(/^\.\//, '');const routerPath = componentPath.replace('../views', '').replace(/\/index.ts$/, '');if (!componentPath.includes('components')) {routerList.push({path: routerPath,name: component.default.name,component: () => import(/* @vite-ignore */componentPath),meta: {title: component.default.title || DEFAULT_DOCUMENT_TITLE,// skeleton: component.skeleton, // TODO 待处理页面骨架屏// background: component.backgroundColor, // TODO 待处理页面级别颜色},});}});return routerList;
};

引入 /router/utils.ts

/router/index.ts

import { createRouter, createWebHistory } from "vue-router";
import HomeView from "@/views/layout/index";
import { vueRouters } from "./utils";const router = createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [......vueRouters()],
});
export default router;

在这里插入图片描述

二、webpack 配置动态路由

webpack使用require.context获取文件路径

  • /router/utils.ts
/*** 路由配置文件*/import { DEFAULT_DOCUMENT_TITLE } from '@/const/base';
import type { RouteRecordRaw } from 'vue-router';function getComponent() {return require.context('../views', true, /\.ts$/);
}// 获取路由文件
export const vueRouters = (): RouteRecordRaw[] => {const routerList: RouteRecordRaw[] = [];const requireRouters = getComponent();requireRouters.keys().forEach((fileSrc: string) => {const viewSrc = requireRouters(fileSrc);const component = viewSrc.default;const componentPath = fileSrc.replace(/^\.\//, '');const routerPath = componentPath.replace(/(\S+)index.ts$/, '/$1index.html');if (component.name !== 'Home' && !component.isOffLine) {routerList.push({path: routerPath,name: component.name,component: () => import(`@/views/${componentPath}`),meta: {title: component.title || DEFAULT_DOCUMENT_TITLE,},});}});return routerList;
};export default vueRouters();

使用同vite


总结

vite 和 webpack 不同于获取文件格式,获取后的操作基本一致

如有启发,可点赞收藏哟~

http://www.ds6.com.cn/news/59363.html

相关文章:

  • 方维网站建设品牌推广经典案例
  • 商务网站建设策划书怎么引流推广自己的产品
  • 做nba直播网站有哪些人百度影响力排名顺序
  • 专业外包网站建设公司河南纯手工seo
  • 网站建设规划书3000字软文批发网
  • 出口做谷歌网站什么是网络营销含义
  • 织梦二次开发手机网站网站制作建设
  • 东莞的网站建设公司专业的google推广公司
  • 教育培训机构官网合肥seo排名扣费
  • 开源免费企业网站系统dz论坛如何seo
  • 国外做足球数据的网站有哪些巨量引擎app
  • 做网单哪个网站最好用app制作公司
  • 兰州手机网站东莞seo建站咨询
  • 网站建设 seo外贸平台
  • 百度企业信用长沙seo推广
  • 动态图网站怎么做dw上海知名的seo推广咨询
  • 做网站包含微信公众号吗b站视频怎么快速推广
  • 编程scratch网站seo网站介绍
  • wordpress做视频播放网站sem论坛
  • wordpress 联盟插件上海网站建设优化
  • 网站制作费可以做业务宣传费如何制作一个个人网站
  • 凡科网网页版登录入口长春seo公司哪家好
  • 邢台网站建设免费做网站排名百度投诉热线中心客服
  • 网站购物车功能怎么做十大免费最亏的免费app
  • 用table做的网站淘宝流量网站
  • 注册网站流程怎么推广公司网站
  • 高端网站建设urkeji怎么找一手app推广代理
  • 装修网站设计平台平面设计培训费用一般是多少
  • 成都公司展厅设计公司汕头seo网站建设
  • 做汽车精品的网站项目优化seo