vue webpack build资源相对路径的问题及解决方法

这篇文章主要介绍了vue webpack build资源相对路径的问题,本文通过实例代码给大家介

vue webpack build资源相对路径的问题及解决方法

这篇文章主要介绍了vue webpack build资源相对路径的问题,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
默认情况webpack+vue-cli打包的css、js等静态资源路径都是绝对的,即static在根目录下,如果部署到带有文件夹目录的项目中,资源路径就会出错。
如图:

解决方法:
在webpack.prod.conf.js中,output中添加或者修改为 publicPath: ‘./\’;

output: {
publicPath: \’./\’,
path: config.build.assetsRoot,
filename: utils.assetsPath(\’js/[name].[chunkhash].js\’),
chunkFilename: utils.assetsPath(\’js/[id].[chunkhash].js\’)
},

这是修改了js,css引用地址,那么image引用地址呢?

config文件夹下面的index
build: {
// Template for index.html
index: path.resolve(__dirname, \’../monitor01/index.html\’),
// Paths
assetsRoot: path.resolve(__dirname, \’../monitor01\’),
assetsSubDirectory: \’static\’,
assetsPublicPath: \’./\’,

}

更改图片地址也为相对路径,修改build下,utils.js文件.

if (options.extract) {
return ExtractTextPlugin.extract({
use: loaders,
fallback: \’vue-style-loader\’,
publicPath: \’../../\’
})
} else {
return [\’vue-style-loader\’].concat(loaders)
}

总结
到此这篇关于vue webpack build资源相对路径的问题及解决方法的文章就介绍到这了,希望大家以后多多支持!

作者: liuzhihao

为您推荐

返回顶部