73 lines
2.1 KiB
TypeScript
73 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
|
||
* 注意:上面提到的仅限外网使用也不是完全肯定的,如果你们公司内网部署的有相关js、css文件,也可以将下面配置对应改一下,整一套内网版cdn
|
||
*/
|
||
export const cdn = importToCDN({
|
||
//(prodUrl解释: name: 对应下面modules的name,version: 自动读取本地package.json中dependencies依赖中对应包的版本号,path: 对应下面modules的path,当然也可写完整路径,会替换prodUrl)
|
||
// prodUrl: 'https://cdn.bootcdn.net/ajax/libs/{name}/{version}/{path}',
|
||
prodUrl: 'https://unpkg.com/{name}@{version}/{path}',
|
||
modules: [
|
||
{
|
||
name: 'vue',
|
||
var: 'Vue',
|
||
path: 'dist/vue.global.prod.js',
|
||
},
|
||
{
|
||
name: 'vue-router',
|
||
var: 'VueRouter',
|
||
path: 'dist/vue-router.global.js',
|
||
},
|
||
{
|
||
name: 'vue-i18n',
|
||
var: 'VueI18n',
|
||
path: 'dist/vue-i18n.global.prod.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: 'lib/index.iife.js',
|
||
},
|
||
{
|
||
name: 'pinia',
|
||
var: 'Pinia',
|
||
path: 'dist/pinia.iife.js',
|
||
},
|
||
{
|
||
name: 'element-plus',
|
||
var: 'ElementPlus',
|
||
path: 'dist/index.full.js',
|
||
css: 'dist/index.css',
|
||
},
|
||
{
|
||
name: 'axios',
|
||
var: 'axios',
|
||
path: 'dist/axios.min.js',
|
||
},
|
||
{
|
||
name: 'dayjs',
|
||
var: 'dayjs',
|
||
path: 'dayjs.min.js',
|
||
},
|
||
{
|
||
name: 'echarts',
|
||
var: 'echarts',
|
||
path: 'dist/echarts.min.js',
|
||
},
|
||
{
|
||
name: 'md-editor-v3',
|
||
var: 'MdEditorV3',
|
||
path: 'lib/umd/index.js',
|
||
css: 'lib/style.css',
|
||
},
|
||
{
|
||
name: 'pinyin-pro',
|
||
var: 'pinyinPro',
|
||
path: 'dist/index.mjs',
|
||
},
|
||
],
|
||
});
|