63 lines
2.1 KiB
TypeScript
63 lines
2.1 KiB
TypeScript
import { Plugin as importToCDN } from "vite-plugin-cdn-import";
|
||
|
||
/**
|
||
* @description 打包时采用`cdn`模式,仅限外网使用(默认不采用,如果需要采用cdn模式,请在 .env.production 文件,将 VITE_CDN 设置成true)
|
||
* 平台采用国内cdn:https://www.bootcdn.cn,当然你也可以选择 https://unpkg.com 或者 https://www.jsdelivr.com
|
||
* 提醒:mockjs不能用cdn模式引入,会报错。正确的方式是,生产环境删除mockjs,使用真实的后端请求
|
||
* 注意:上面提到的仅限外网使用也不是完全肯定的,如果你们公司内网部署的有相关js、css文件,也可以将下面配置对应改一下,整一套内网版cdn
|
||
*/
|
||
export const cdn = importToCDN({
|
||
//(prodUrl解释: name: 对应下面modules的name,version: 自动读取本地package.json中dependencies依赖中对应包的版本号,path: 对应下面modules的path)
|
||
prodUrl: "https://cdn.bootcdn.net/ajax/libs/{name}/{version}/{path}",
|
||
modules: [
|
||
{
|
||
name: "vue",
|
||
var: "Vue",
|
||
path: "vue.global.prod.min.js"
|
||
},
|
||
{
|
||
name: "vue-router",
|
||
var: "VueRouter",
|
||
path: "vue-router.global.min.js"
|
||
},
|
||
// 项目中没有直接安装vue-demi,但是pinia用到了,所以需要在引入pinia前引入vue-demi(https://github.com/vuejs/pinia/blob/v2/packages/pinia/package.json#L77)
|
||
{
|
||
name: "vue-demi",
|
||
var: "VueDemi",
|
||
path: "index.iife.min.js"
|
||
},
|
||
{
|
||
name: "pinia",
|
||
var: "Pinia",
|
||
path: "pinia.iife.min.js"
|
||
},
|
||
{
|
||
name: "element-plus",
|
||
var: "ElementPlus",
|
||
path: "index.full.min.js",
|
||
css: "index.min.css"
|
||
},
|
||
{
|
||
name: "axios",
|
||
var: "axios",
|
||
path: "axios.min.js"
|
||
},
|
||
{
|
||
name: "dayjs",
|
||
var: "dayjs",
|
||
path: "dayjs.min.js"
|
||
},
|
||
{
|
||
name: "echarts",
|
||
var: "echarts",
|
||
path: "echarts.min.js"
|
||
},
|
||
{
|
||
name: "lodash",
|
||
var: "lodash",
|
||
// 可写`完整路径`,会替换`prodUrl`
|
||
path: "https://cdn.bootcdn.net/ajax/libs/lodash.js/4.17.21/lodash.min.js"
|
||
}
|
||
]
|
||
});
|