码迷,mamicode.com
首页 > 其他好文 > 详细

vue-cli脚手架每行注释

时间:2018-02-14 17:52:54      阅读:442      评论:0      收藏:0      [点我收藏+]

标签:cat   开发模式   hub   使用   func   rewrite   file   sid   ade   

  1 .babelrc文件
  2 
  3 {
  4 
  5   // 此项指明,转码的规则
  6 
  7   "presets": [
  8 
  9       // env项是借助插件babel-preset-env,下面这个配置说的是babel对es6,es7,es8进行转码,并且设置amd,commonjs这样的模块化文件,不进行转码
 10 
 11       ["env", { "modules": false }],
 12 
 13       // 下面这个是不同阶段出现的es语法,包含不同的转码插件
 14 
 15       "stage-2"
 16 
 17   ],
 18 
 19   // 下面这个选项是引用插件来处理代码的转换,transform-runtime用来处理全局函数和优化babel编译
 20 
 21   "plugins": ["transform-runtime"],
 22 
 23   // 下面指的是在生成的文件中,不产生注释
 24 
 25   "comments": false,
 26 
 27   // 下面这段是在特定的环境中所执行的转码规则,当环境变量是下面的test就会覆盖上面的设置
 28 
 29   "env": {
 30 
 31       // test 是提前设置的环境变量,如果没有设置BABEL_ENV则使用NODE_ENV,如果都没有设置默认就是development
 32 
 33       "test": {
 34 
 35           "presets": ["env", "stage-2"],
 36 
 37           // instanbul是一个用来测试转码后代码的工具
 38 
 39           "plugins": ["istanbul"]
 40 
 41       }
 42 
 43   }
 44 
 45 }
 46 
 47 
 48 
 49 vue-cli build目录中的 utils.js 配置文件
 50 
 51 此配置文件是vue开发环境的wepack相关配置文件,主要用来处理css-loader和vue-style-loader
 52 
 53 // 引入nodejs路径模块
 54 
 55 var path = require(‘path‘)
 56 
 57 // 引入config目录下的index.js配置文件
 58 
 59 var config = require(‘../config‘)
 60 
 61 // 引入extract-text-webpack-plugin插件,用来将css提取到单独的css文件中
 62 
 63 // 详情请看(1)
 64 
 65 var ExtractTextPlugin = require(‘extract-text-webpack-plugin‘)
 66 
 67 // exports其实就是一个对象,用来导出方法的最终还是使用module.exports,此处导出assetsPath
 68 
 69 exports.assetsPath = function (_path) {
 70 
 71     // 如果是生产环境assetsSubDirectory就是‘static‘,否则还是‘static‘,
 72 
 73     var assetsSubDirectory = process.env.NODE_ENV === ‘production‘
 74 
 75         ? config.build.assetsSubDirectory
 76 
 77         : config.dev.assetsSubDirectory
 78 
 79     // path.join和path.posix.join的区别就是,前者返回的是完整的路径,后者返回的是完整路径的相对根路径
 80 
 81     // 也就是说path.join的路径是C:a/a/b/xiangmu/b,那么path.posix.join就是b
 82 
 83     return path.posix.join(assetsSubDirectory, _path)
 84 
 85     // 所以这个方法的作用就是返回一个干净的相对根路径
 86 
 87 }
 88 
 89 
 90 
 91 // 下面是导出cssLoaders的相关配置
 92 
 93 exports.cssLoaders = function (options) {
 94 
 95   // options如果没值就是空对象
 96 
 97   options = options || {}
 98 
 99   // cssLoader的基本配置
100 
101   var cssLoader = {
102 
103       loader: ‘css-loader‘,
104 
105       options: {
106 
107           // options是用来传递参数给loader的
108 
109           // minimize表示压缩,如果是生产环境就压缩css代码
110 
111           minimize: process.env.NODE_ENV === ‘production‘,
112 
113           // 是否开启cssmap,默认是false
114 
115           sourceMap: options.sourceMap
116 
117       }
118 
119   }
120 
121 
122 
123   // generate loader string to be used with extract text plugin
124 
125   function generateLoaders (loader, loaderOptions) {
126 
127       // 将上面的基础cssLoader配置放在一个数组里面
128 
129       var loaders = [cssLoader]
130 
131       // 如果该函数传递了单独的loader就加到这个loaders数组里面,这个loader可能是less,sass之类的
132 
133       if (loader) {
134 
135           loaders.push({
136 
137               // 加载对应的loader
138 
139               loader: loader + ‘-loader‘,
140 
141               // Object.assign是es6的方法,主要用来合并对象的,浅拷贝
142 
143               options: Object.assign({}, loaderOptions, {
144 
145                   sourceMap: options.sourceMap
146 
147               })
148 
149           })
150 
151       }
152 
153 
154 
155       // Extract CSS when that option is specified
156 
157       // (which is the case during production build)
158 
159       // 注意这个extract是自定义的属性,可以定义在options里面,主要作用就是当配置为true就把文件单独提取,false表示不单独提取,这个可以在使用的时候单独配置,瞬间觉得vue作者好牛逼
160 
161       if (options.extract) {
162 
163           return ExtractTextPlugin.extract({
164 
165               use: loaders,
166 
167               fallback: ‘vue-style-loader‘
168 
169           })
170 
171       } else {
172 
173           return [‘vue-style-loader‘].concat(loaders)
174 
175       }
176 
177       // 上面这段代码就是用来返回最终读取和导入loader,来处理对应类型的文件
178 
179   }
180 
181 
182 
183   // https://vue-loader.vuejs.org/en/configurations/extract-css.html
184 
185   return {
186 
187       css: generateLoaders(), // css对应 vue-style-loader 和 css-loader
188 
189       postcss: generateLoaders(), // postcss对应 vue-style-loader 和 css-loader
190 
191       less: generateLoaders(‘less‘), // less对应 vue-style-loader 和 less-loader
192 
193       sass: generateLoaders(‘sass‘, { indentedSyntax: true }), // sass对应 vue-style-loader 和 sass-loader
194 
195       scss: generateLoaders(‘sass‘), // scss对应 vue-style-loader 和 sass-loader
196 
197       stylus: generateLoaders(‘stylus‘), // stylus对应 vue-style-loader 和 stylus-loader
198 
199       styl: generateLoaders(‘stylus‘) // styl对应 vue-style-loader 和 styl-loader 
200 
201   }
202 
203 }
204 
205 
206 
207 // Generate loaders for standalone style files (outside of .vue)
208 
209 // 下面这个主要处理import这种方式导入的文件类型的打包,上面的exports.cssLoaders是为这一步服务的
210 
211 exports.styleLoaders = function (options) {
212 
213   var output = []
214 
215   // 下面就是生成的各种css文件的loader对象
216 
217   var loaders = exports.cssLoaders(options)
218 
219   for (var extension in loaders) {
220 
221       // 把每一种文件的laoder都提取出来
222 
223       var loader = loaders[extension]
224 
225       output.push({
226 
227           // 把最终的结果都push到output数组中,大事搞定
228 
229           test: new RegExp(‘\\.‘ + extension + ‘$‘),
230 
231           use: loader
232 
233       })
234 
235   }
236 
237   return output
238 
239 }
240 
241 
242 
243 
244 vue-cli脚手架config目录下index.js配置文件
245 
246 此配置文件是用来定义开发环境和生产环境中所需要的参数
247 
248 // see http://vuejs-templates.github.io/webpack for documentation.
249 
250 // path是node.js的路径模块,用来处理路径统一的问题
251 
252 var path = require(‘path‘)
253 
254 
255 
256 module.exports = {
257 
258   // 下面是build也就是生产编译环境下的一些配置
259 
260   build: {
261 
262       // 导入prod.env.js配置文件,只要用来指定当前环境,详细见(1)
263 
264       env: require(‘./prod.env‘),
265 
266       // 下面是相对路径的拼接,假如当前跟目录是config,那么下面配置的index属性的属性值就是dist/index.html
267 
268       index: path.resolve(__dirname, ‘../dist/index.html‘),
269 
270       // 下面定义的是静态资源的根目录 也就是dist目录
271 
272       assetsRoot: path.resolve(__dirname, ‘../dist‘),
273 
274       // 下面定义的是静态资源根目录的子目录static,也就是dist目录下面的static
275 
276       assetsSubDirectory: ‘static‘,
277 
278       // 下面定义的是静态资源的公开路径,也就是真正的引用路径
279 
280       assetsPublicPath: ‘/‘,
281 
282       // 下面定义是否生成生产环境的sourcmap,sourcmap是用来debug编译后文件的,通过映射到编译前文件来实现
283 
284       productionSourceMap: true,
285 
286       // Gzip off by default as many popular static hosts such as
287 
288       // Surge or Netlify already gzip all static assets for you.
289 
290       // Before setting to `true`, make sure to:
291 
292       // npm install --save-dev compression-webpack-plugin
293 
294       // 下面是是否在生产环境中压缩代码,如果要压缩必须安装compression-webpack-plugin
295 
296       productionGzip: false,
297 
298       // 下面定义要压缩哪些类型的文件
299 
300       productionGzipExtensions: [‘js‘, ‘css‘],
301 
302       // Run the build command with an extra argument to
303 
304       // View the bundle analyzer report after build finishes:
305 
306       // `npm run build --report`
307 
308       // Set to `true` or `false` to always turn it on or off
309 
310       // 下面是用来开启编译完成后的报告,可以通过设置值为true和false来开启或关闭
311 
312       // 下面的process.env.npm_config_report表示定义的一个npm_config_report环境变量,可以自行设置
313 
314       bundleAnalyzerReport: process.env.npm_config_report
315 
316   },
317 
318   dev: {
319 
320       // 引入当前目录下的dev.env.js,用来指明开发环境,详见(2)
321 
322       env: require(‘./dev.env‘),
323 
324       // 下面是dev-server的端口号,可以自行更改
325 
326       port: 8080,
327 
328       // 下面表示是否自定代开浏览器
329 
330       autoOpenBrowser: true,
331 
332       assetsSubDirectory: ‘static‘,
333 
334       assetsPublicPath: ‘/‘,
335 
336       // 下面是代理表,作用是用来,建一个虚拟api服务器用来代理本机的请求,只能用于开发模式
337 
338       // 详见(3)
339 
340       proxyTable: {},
341 
342       // CSS Sourcemaps off by default because relative paths are "buggy"
343 
344       // with this option, according to the CSS-Loader README
345 
346       // (https://github.com/webpack/css-loader#sourcemaps)
347 
348       // In our experience, they generally work as expected,
349 
350       // just be aware of this issue when enabling this option.
351 
352       // 是否生成css,map文件,上面这段英文就是说使用这个cssmap可能存在问题,但是按照经验,问题不大,可以使用
353 
354       // 给人觉得没必要用这个,css出了问题,直接控制台不就完事了
355 
356       cssSourceMap: false
357 
358   }
359 
360 }
361 
362 注释
363 
364 (1)下面是prod.env.js的配置内容
365 
366   module.exports = {
367 
368       // 作用很明显,就是导出一个对象,NODE_ENV是一个环境变量,指定production环境
369 
370       NODE_ENV: ‘"production"‘
371 
372   }
373 
374 (2)下面是dev.env.js的配置内容
375 
376   // 首先引入的是webpack的merge插件,该插件是用来合并对象,也就是配置文件用的,相同的选项会被覆盖,至于这里为什么多次一举,可能另有他图吧
377 
378   var merge = require(‘webpack-merge‘)
379 
380   // 导入prod.env.js配置文件
381 
382   var prodEnv = require(‘./prod.env‘)
383 
384   // 将两个配置对象合并,最终结果是 NODE_ENV: ‘"development"‘
385 
386   module.exports = merge(prodEnv, {
387 
388       NODE_ENV: ‘"development"‘
389 
390   })
391 
392 (3)下面是proxyTable的一般用法
393 
394   vue-cli使用这个功能是借助http-proxy-middleware插件,一般解决跨域请求api
395 
396   proxyTable: {
397 
398       ‘/list‘: {
399 
400           target: ‘http://api.xxxxxxxx.com‘, -> 目标url地址
401 
402           changeOrigin: true, -> 指示是否跨域
403 
404           pathRewrite: {
405 
406           ‘^/list‘: ‘/list‘ -> 可以使用 /list 等价于 api.xxxxxxxx.com/list
407 
408           }
409 
410       }
411 
412   }

 来源:vue-cli脚手架每行注释

vue-cli脚手架每行注释

标签:cat   开发模式   hub   使用   func   rewrite   file   sid   ade   

原文地址:https://www.cnblogs.com/mhxy13867806343/p/8448589.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!