zhoudw
2022-01-11 25b0b96005ed1f1fb91b0a0677ff01a7cc312869
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
'use strict'
require('./check-versions')()
 
process.env.NODE_ENV = 'development'
process.env.NODE_ENV_SELF = 'development'
 
const ora = require('ora')
const rm = require('rimraf')
const path = require('path')
const chalk = require('chalk')
const webpack = require('webpack')
const config = require('../config')
const webpackConfig = require('./webpack.prod.conf')
const configFilePath = './static/config.js'
const spinner = ora('building for production...')
spinner.start()
    //读取配置文件
const CONFIG_ENV = require('../config/dev.env')
const fs = require('fs')
    //组装配置文件内容
let CONFIG_ENV_STRING = '';
for (let i in CONFIG_ENV) {
    CONFIG_ENV_STRING += i + ':' + CONFIG_ENV[i] + ','
}
const BUILD_DEV = `let config={${CONFIG_ENV_STRING}};module.exports = config;`
fs.writeFileSync(configFilePath, BUILD_DEV)
rm(path.join(config.build_dev.assetsRoot, config.build_dev.assetsSubDirectory), err => {
    if (err) throw err
    webpack(webpackConfig, (err, stats) => {
        spinner.stop()
        if (err) throw err
        process.stdout.write(stats.toString({
            colors: true,
            modules: false,
            children: false, // If you are using ts-loader, setting this to true will make TypeScript errors show up during build.
            chunks: false,
            chunkModules: false
        }) + '\n\n')
        if (stats.hasErrors()) {
            console.log(chalk.red('  Build failed with errors.\n'))
            process.exit(1)
        }
        //删除配置文件
        fs.unlinkSync(configFilePath);
        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'
        ))
    })
})