当前位置:   article > 正文

vue.config.js的全部配置_vueconfig.js配置

vueconfig.js配置
  1. const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
  2. const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzer
  3. const path = require('path')
  4. module.exports = {
  5. // 部署应用包时的基本 URL,从 Vue CLI 3.3 起已弃用baseUrl
  6. publicPath: '/',
  7. // build时构建文件的目录 构建时传入 --no-clean 可关闭该行为
  8. outputDir: 'dist',
  9. // build时放置生成的静态资源 (js、css、img、fonts) 的 (相对于 outputDir 的) 目录
  10. assetsDir: '',
  11. // 指定生成的 index.html 的输出路径 (相对于 outputDir)。也可以是一个绝对路径。
  12. indexPath: 'index.html',
  13. // 默认在生成的静态资源文件名中包含hash以控制缓存
  14. filenameHashing: true,
  15. // 构建多页面应用,页面的配置
  16. pages: {
  17. index: {
  18. // page 的入口
  19. entry: './src/main.js',
  20. // 模板来源
  21. template: 'public/index.html',
  22. // 在 dist/index.html 的输出
  23. filename: 'index.html',
  24. // 当使用 title 选项时,
  25. // template 中的 title 标签需要是 <title><%= htmlWebpackPlugin.options.title %></title>
  26. title: 'Index Page',
  27. // 在这个页面中包含的块,默认情况下会包含
  28. // 提取出来的通用 chunk 和 vendor chunk。
  29. chunks: ['chunk-vendors', 'chunk-common', 'index']
  30. }
  31. // 当使用只有入口的字符串格式时,
  32. // 模板会被推导为 `public/subpage.html`
  33. // 并且如果找不到的话,就回退到 `public/index.html`。
  34. // 输出文件名会被推导为 `subpage.html`。
  35. // subpage: 'src/subpage/main.js'
  36. },
  37. // 是否在开发环境下通过 eslint-loader 在每次保存时 lint 代码 (在生产构建时禁用 eslint-loader)
  38. lintOnSave: process.env.NODE_ENV !== 'production',
  39. // 是否使用包含运行时编译器的 Vue 构建版本
  40. runtimeCompiler: false,
  41. // Babel 显式转译列表
  42. transpileDependencies: [],
  43. // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建
  44. productionSourceMap: true,
  45. // 设置生成的 HTML 中 <link rel="stylesheet"> 和 <script> 标签的 crossorigin 属性(注:仅影响构建时注入的标签)
  46. crossorigin: '',
  47. // 在生成的 HTML 中的 <link rel="stylesheet"> 和 <script> 标签上启用 Subresource Integrity (SRI)
  48. integrity: false,
  49. // 如果这个值是一个对象,则会通过 webpack-merge 合并到最终的配置中
  50. // 如果你需要基于环境有条件地配置行为,或者想要直接修改配置,那就换成一个函数 (该函数会在环境变量被设置之后懒执行)。该方法的第一个参数会收到已经解析好的配置。在函数内,你可以直接修改配置,或者返回一个将会被合并的对象
  51. configureWebpack: {
  52. resolve: { // 配置解析别名
  53. extensions: ['.js', '.vue', '.json'],
  54. alias: {
  55. '@': path.resolve(__dirname, './src'),
  56. 'vue$': 'vue/dist/vue.esm.js',
  57. 'api': path.resolve(__dirname, '../src/api')
  58. }
  59. },
  60. optimization: {
  61. splitChunks: {
  62. chunks: 'all'
  63. }
  64. },
  65. optimization: {
  66. minimizer: [
  67. new UglifyJsPlugin({
  68. uglifyOptions: {
  69. compress: {
  70. warnings: false,
  71. drop_console: true, // console
  72. drop_debugger: false,
  73. pure_funcs: ['console.log'] // 移除console
  74. }
  75. }
  76. })
  77. ]
  78. }
  79. },
  80. // 对内部的 webpack 配置(比如修改、增加Loader选项)(链式操作)
  81. chainWebpack: (config) => {
  82. // config.resolve.alias
  83. // .set('@', resolve('src'))
  84. // 修复HMR
  85. config.resolve.symlinks(true)
  86. // config.plugin('context')
  87. // .use(webpack.ContextReplacementPlugin,
  88. // [/moment[/\\]locale$/, /zh-cn/])
  89. // 打包文件带hash
  90. config.output.filename('[name].[hash].js').end()
  91. // 为了补删除换行而加的配置
  92. config.module
  93. .rule('vue')
  94. .use('vue-loader')
  95. .loader('vue-loader')
  96. .tap(options => {
  97. // modify the options...
  98. options.compilerOptions.preserveWhitespace = true
  99. return options
  100. })
  101. // 修改fonts loader设置
  102. const fontRule = config.module.rule('fonts')
  103. fontRule.test(/\.(eot|ttf|otf|woff|woff2?)(\?.*)?$/)
  104. // 防止将某些 import 的包(package)打包到 bundle 中,而是在运行时(runtime)再去从外部获取这些扩展依赖
  105. config.externals = {
  106. 'vue': 'Vue',
  107. 'element-ui': 'ELEMENT',
  108. 'vue-router': 'VueRouter',
  109. 'vuex': 'Vuex',
  110. 'axios': 'axios'
  111. }
  112. // 打包分析
  113. if (process.env.IS_ANALYZ) {
  114. config.plugin('webpack-report')
  115. .use(BundleAnalyzerPlugin, [{
  116. analyzerMode: 'static'
  117. }])
  118. }
  119. },
  120. // css的处理
  121. css: {
  122. // 当为true时,css文件名可省略 module 默认为 false
  123. modules: false, // 设置为true时,使用全局element-ui会造成无法找到字体和图标文件 .woff .ttf
  124. // 是否将组件中的 CSS 提取至一个独立的 CSS 文件中,当作为一个库构建时,你也可以将其设置为 false 免得用户自己导入 CSS
  125. // 默认生产环境下是 true,开发环境下是 false
  126. extract: false,
  127. // 是否为 CSS 开启 source map。设置为 true 之后可能会影响构建的性能
  128. sourceMap: true,
  129. // 向 CSS 相关的 loader 传递选项(支持 css-loader postcss-loader sass-loader less-loader stylus-loader)
  130. loaderOptions: {
  131. }
  132. },
  133. // 所有 webpack-dev-server 的选项都支持
  134. devServer: {
  135. host: 'localhost',
  136. port: 8080,
  137. https: false,
  138. overlay: {
  139. warnings: false,
  140. errors: true
  141. }
  142. },
  143. // 是否为 Babel 或 TypeScript 使用 thread-loader
  144. parallel: require('os').cpus().length > 1,
  145. // 向 PWA 插件传递选项
  146. pwa: {},
  147. // 可以用来传递任何第三方插件选项
  148. pluginOptions: {}
  149. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/320656
推荐阅读
相关标签
  

闽ICP备14008679号