vue.config.js配置,webpack打包配置详解

注意:
vue-cli3 脚手架搭建完成后,项目目录中没有 vue.config.js 文件,需要手动创建

第一步:手动创建vue.config.js文件,

一般放在和package.json同级目录中,vue.config.js 是一个可选的配置文件,如果项目的 (和 package.json
同级的) 根目录中存在这个文件,那么它会被 @vue/cli-service 自动加载。你也可以使用 package.json 中的 vue
字段,但是注意这种写法需要你严格遵照 JSON 的格式来写。

结构和配置选项如下:

//1.该文件应该导出一个包含了选项的对象:
module.exports={
     
//这个值也可以被设置为空字符串 ('') 或是相对路径 ('./'),这样所有的资源都会被链接为相对路径,这样打出来的包可以被部署在任意路径。
//默认值是:"/"
publicPath:"./",

//把开发服务器架设在根路径,可以使用一个条件式的值:
publicPath:process.env.NODE_ENV==='production'?'/production-sub-path/':"/",
//举个实例使用方式:
publicPath:process.env.NODE_ENV==='production'?'192.168.60.110:8080':'192.168.60.112:8080',


//输出文件目录,
//当运行 vue-cli-service build 时生成的生产环境构建文件的目录。注意目标目录在构建之前会被清除 (构建时传入 --no-clean 可关闭该行为)。
//默认值是dist
outputDir:"dist",

//放置生成的静态资源 (js、css、img、fonts) 的目录。注意:从生成的资源覆写 filename 或 chunkFilename 时,assetsDir 会被忽略。
//默认值是空""
assetsDir:"static",

//指定生成的 index.html 的输出路径 (相对于 outputDir)。也可以是一个绝对路径。
//默认值是index.html
indexPath:"index.html",
}

构建多页面配置如下:

module.exports={
     
//默认情况下,生成的静态资源在它们的文件名中包含了 hash 以便更好的控制缓存。然而,这也要求 index 的 HTML 是被 Vue CLI 自动生成的。如果你无法使用 Vue CLI 生成的 index HTML,你可以通过将这个选项设为 false 来关闭文件名哈希。
//默认值是true
filenameHashing:false,

//在 multi-page(多页)模式下构建应用。每个“page”应该有一个对应的 JavaScript 入口文件。
//其值应该是一个对象,对象的 key 是入口的名字,value 是:
//一个指定了 entry, template, filename, title 和 chunks 的对象 (除了 entry 之外都是可选的);或一个指定其 entry 的字符串。
//pages用于多页配置,默认时undefined
//注:当在 多页应用 模式下构建时,webpack 配置会包含不一样的插件 (这时会存在多个 html-webpack-plugin 和 preload-webpack-plugin 的实例)。如果你试图修改这些插件的选项,请确认运行 vue inspect。
//默认值是undefined
pages:{
     
	index:{
     
	//page的入口文件
	entry:"src/index/main.js",
	
	//模板文件来源
	template:"public/index.html",
	
	//在dist/index.html的输出文件
	filename:"index.html",
	
	//当使用页面的title选项时,
	//template中的title标签需要是<%= htmlWebpackPlugin.options.title %>
	title:"Index Page",
	
	//在这个页面中包含的块,默认情况下会包含
	//提取出来的通用chunk和vendor chunk
	chunks:['chunk-vendors','chunk-common','index']
	},
	
//当使用只有入口的字符串格式时,
//模板文件默认是'public/subpage.html'
//如果不存在,就回退到'public/index.html'
//输出文件默认是'subpage.html'
subpage:'src/subpage/main.js',

//是否在保存的时候使用 `eslint-loader` 进行检查。 有效的值:`ture` | `false` | `"error"`  当设置为 `"error"` 时,检查出的错误会触发编译失败。
//默认值是true
lintOnSave:true,

//是否使用包含运行时编译器的 Vue 构建版本。设置为 true 后你就可以在 Vue 组件中使用 template 选项了,但是这会让你的应用额外增加 10kb 左右。
//默认值是false
runtimeCompiler:false,

//默认情况下 babel-loader 会忽略所有 node_modules 中的文件。如果你想要通过 Babel 显式转译一个依赖,可以在这个选项中列出来。
//默认值是空数组[]
transpileDependencies:"",

//如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
//默认值:true
productionSourceMap:false,

//设置生成的 HTML 中 
                    
                    

你可能感兴趣的:(vue,webpack,vue.js,javascript)