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

金华网站建设方案报价2345纯净版推广包

金华网站建设方案报价,2345纯净版推广包,内容平台策划书,企业二级网站怎么做文章目录 前言定义项目页面格式一、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.mmbaike.com/news/104975.html

相关文章:

  • 郸城县做网站seo自学教程推荐
  • 辽宁网站制作网店推广实训报告
  • 图片代码如何做网站网络营销网站推广
  • 京东的网站建设介绍网站内链优化
  • 建设网站需要的配置郑州百度推广公司
  • 网址导航建站上海seo博客
  • 企业网站推广平台网络营销主要有哪些特点
  • 做网站需要绑定电脑ip吗怎么自己做网站
  • 设计摄影作品苏州企业网站关键词优化
  • 宠物网站制作费用明细网络营销的方式和方法
  • wordpress强大的电商seo优化工具
  • 英语卷子哪个网站可以做西安seo外包公司
  • 昆明网站建设加q.479185700谷歌paypal官网
  • 钟楼做网站qq营销
  • 创新的武进网站建设seo顾问服务 乐云践新专家
  • 怎么做网站扫描合肥网络优化推广公司
  • html大作业网页代码一个网站的seo优化有哪些
  • 物流网站风格品牌营销与推广
  • 有哪些企业会找人做网站建设全国各城市疫情搜索高峰进度
  • 怎么做淘宝网站的网页九个关键词感悟中国理念
  • 百家号wordpress搜索引擎优化seo是什么
  • 深圳网站建设找哪家好seo引擎优化方案
  • 网站开发与管理期末考试网店运营培训
  • 响应式网站制作工具google seo是什么意思
  • 珠海市企业网站制作品牌百度推广的方式有哪些
  • 怎么做免费网站推广营销渠道策略
  • 怎么自己制作微信小程序seo分析seo诊断
  • 太原网站建设baidu店铺推广软文案例
  • 深圳设计网站培训学校西安seo顾问培训
  • 推荐几个网站网络竞价