码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2017-08-24 17:55:45      阅读:283      评论:0      收藏:0      [点我收藏+]

标签:bsp   top   log   mod   npm   控制   相关   tostring   spi   

下面是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相关文件说明(6)build.js

标签:bsp   top   log   mod   npm   控制   相关   tostring   spi   

原文地址:http://www.cnblogs.com/simleSmith/p/7424047.html

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