代码拉取完成,页面将自动刷新
同步操作将从 Sam-meng/vue-cli 高级模板 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
const autoprefixer = require('autoprefixer')
const postcssPxtorem = require('postcss-pxtorem') // @H5 将 px 转成 rem
const _ = require('lodash')
const { join } = require('path')
const env = process.env
const isDev = env.NODE_ENV === 'development'
/* 当代理的前缀为空时 */
if (isDev) {
const isEmpty = prefix => prefix === '' || prefix === '/'
if (isEmpty(env.VUE_APP_BASEURL_API)) env.VUE_APP_BASEURL_API = '/@API'
}
/**
* @type {import('@vue/cli-service').ConfigFunction}
*/
module.exports = () => ({
devServer: {
/* 更详细的配置规则:https://webpack.docschina.org/configuration/dev-server/#devserver-proxy */
proxy: {
[env.VUE_APP_BASEURL_API]: {
pathRewrite: { '^/@API': '' },
target: env.DEV_PROXY_TARGET_API,
},
},
},
assetsDir: 'static-hash',
publicPath: env.BASE_URL,
css: {
extract: false,
loaderOptions: {
less: {
globalVars: {
hack: `true; @import '${join(__dirname, './src/styles/vars.less')}'`,
},
},
postcss: {
plugins: function({ resourcePath: path }) {
const pxtorem = postcssPxtorem({ propList: ['*'] }) // @H5 将 px 转成 rem
if (
/* 跳过 autoprefixer */
/[\\/]node_modules[\\/].+\.css$/.test(path) ||
/[\\/]src[\\/]libs[\\/].+\.css$/.test(path) ||
(isDev && env.DEV_CSS_AUTOPREFIXER !== 'true')
) {
return [pxtorem]
}
return [pxtorem, autoprefixer]
},
},
},
sourceMap: isDev ? env.DEV_CSS_SOURCEMAP === 'true' : false,
},
productionSourceMap: env.VUE_APP_ENV === 'stage',
configureWebpack: config => {
if (isDev) config.devtool = 'source-map'
config.optimization.splitChunks.cacheGroups.vendors.test = module => {
const { resource: path } = module
if (!path) return false
if (
/* 为了 chunk-vendors*.js 的稳定性,需要排除掉经过 babel 插件处理成按需引入的模块(详见 babel.config.js) */
/[\\/]node_modules[\\/]element-ui[\\/]/.test(path) || // @PC.element-ui
/[\\/]node_modules[\\/]vant[\\/]/.test(path) || // @H5.vant
/[\\/]node_modules[\\/]lodash[\\/]/.test(path)
) {
return false
}
return /[\\/]node_modules[\\/]|[\\/]src[\\/]libs[\\/]/.test(path) // 将这些初始化时的依赖包纳入 chunk-vendors*.js(其它的则纳入 app*.js)
}
},
chainWebpack: config => {
/* 跳过 babel-loader */
config.module.rule('js').exclude.add(path => {
return /[\\/]src[\\/]libs[\\/].+\.js$/.test(path)
})
const svgSpriteIconsDir = join(__dirname, './src/components/SvgIcon/icons/')
config.module.rule('svg').exclude.add(svgSpriteIconsDir)
config.module
.rule('svg-sprite')
.after('svg')
.test(/\.(svg)(\?.*)?$/)
.include.add(svgSpriteIconsDir)
.end()
.use('svg-sprite-loader')
.loader('svg-sprite-loader')
.options({ symbolId: '$svgSpriteIcon_[name]' })
.end()
.use('svgo-loader')
.loader('svgo-loader')
/* @H5.vant */
const vant = config.module
.rule('less')
.oneOf('vant')
.before('vue-modules')
.test(/[\\/]node_modules[\\/]vant[\\/]/)
config.module
.rule('less')
.oneOf('normal')
.toConfig()
.use.forEach(({ __useName, loader, options = {} }) => {
const ops = _.cloneDeep(options)
if (__useName === 'less-loader') {
delete ops.globalVars
ops.modifyVars = {
hack: `true; @import '${join(__dirname, './src/vant/vars.less')}'`,
}
}
vant
.use(__useName)
.loader(loader)
.options(ops)
})
if (config.plugins.has('copy')) {
config.plugin('copy').tap(args => {
args[0][0].ignore.push('.eslintrc.js', '.prettierrc.js')
args[0][0].transform = function(content, path) {
if (
/* 让 public 中的其它文件也支持 EJS 语法(传入运行时可用的环境变量) */
/\.(html|htm|js|json)$/.test(path) &&
/[\\/]public[\\/]libs[\\/]/.test(path) === false
) {
const ejsData = _.pickBy(env, (val, key) =>
/^(NODE_ENV|BASE_URL|VUE_APP_.*)$/.test(key),
)
content = _.template(`${content}`, { sourceURL: path })(ejsData)
}
return content
}
return args
})
}
},
})
if (env.NODE_ENV) {
if (
/^(development|production|test)$/.test(env.NODE_ENV) === false ||
/^(dev|stage|prod)$/.test(env.VUE_APP_ENV) === false ||
(env.NODE_ENV === 'development' && env.VUE_APP_ENV !== 'dev') ||
(env.NODE_ENV === 'production' && env.VUE_APP_ENV === 'dev') ||
(env.NODE_ENV === 'production' && env.VUE_APP_MOCK === undefined)
) {
throw new Error('环境变量配置错误或不兼容或缺失')
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。