vue-cli脚手架npm相关文件说明build.js

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue-cli脚手架npm相关文件说明build.js相关的知识,希望对你有一定的参考价值。

下面是build/vue-loader.conf.js中相关代码和配置的说明

/*
 * npm run build 构建执行文件,主要用于生产环境
 * 建议先查阅webapck.prod.conf.js
*/

// npm和node版本检查
require(‘./check-versions‘)()

// 设置环境变量为production
// process.env 是node环境内置的变量,在命令行里可以通过 set 变量名=值的方式来设置,等价于 set NODE_ENV=‘production‘
process.env.NODE_ENV = ‘production‘

var ora = require(‘ora‘) // ora是一个命令行转圈圈动画插件,好看用的
var rm = require(‘rimraf‘) // rimraf插件是用来执行UNIX命令rm和-rf的用来删除文件夹和文件,清空旧的文件
var path = require(‘path‘)
var chalk = require(‘chalk‘) // chalk插件,用来在命令行中输出不同颜色的文字
var webpack = require(‘webpack‘)
var config = require(‘../config‘) // 项目配置文件
var webpackConfig = require(‘./webpack.prod.conf‘) // 生产环境的Webpack配置文件

var spinner = ora(‘building for production...‘) // 开启转圈圈动画
spinner.start()

// 调用rm方法,第一个参数和第二个参数分别是 ../dist 和 static,表示删除路径下面的所有文件
rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => {
  if (err) throw err // 如果删除的过程中出现错误,就抛出这个错误,同时程序终止
  // 调用webPack执行构建
  webpack(webpackConfig, function (err, stats) {
    spinner.stop()
    if (err) throw err
    process.stdout.write(stats.toString({ // stats对象中保存着编译过程中的各种消息
      colors: true, // 增加控制台颜色开关
      modules: false, // 不增加内置模块信息
      children: false, // 不增加子级信息
      chunks: false, // 允许较少的输出
      chunkModules: false // 不将内置模块的信息加到包信息
    }) + ‘\\n\\n‘)

    console.log(chalk.cyan(‘  Build complete.\\n‘))
    console.log(chalk.yellow(
      ‘  Tip: built files are meant to be served over an HTTP server.\\n‘ +
      ‘  Opening index.html over file:// won\\‘t work.\\n‘
    ))
  })
})

参考:http://www.cnblogs.com/ye-hcj/archive/2017/06.html

 

以上是关于vue-cli脚手架npm相关文件说明build.js的主要内容,如果未能解决你的问题,请参考以下文章

vue-cli脚手架npm相关文件说明check-versions.js

vue-cli脚手架npm相关文件说明dev-server.js

vue-cli脚手架npm相关文件说明vue-loader.conf.js

vue-cli脚手架npm相关文件说明-2webpack.prod.conf.js

vue-cli中的build.js配置文件详细解析

vue-cli脚手架build目录中check-versions.js的配置