vue-cli脚手架npm相关文件说明check-versions.js
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue-cli脚手架npm相关文件说明check-versions.js相关的知识,希望对你有一定的参考价值。
系列文章传送门:
下面是build/check-versions.js中相关代码和配置的说明
/* * 版本验证工具 * */ var chalk = require(‘chalk‘) // 下面这个是semver插件,是用来对特定的版本号做判断的,比如 // semver.gt(‘1.2.3‘,‘9.8.7‘) false 1.2.3版本比9.8.7版本低 // semver.satisfies(‘1.2.3‘,‘1.x || >=2.5.0 || 5.0.0 - 7.2.3‘) true 1.2.3的版本符合后面的规则 var semver = require(‘semver‘) var packageConfig = require(‘../package.json‘) var shell = require(‘shelljs‘) // 脚本可以通过 child_process 模块新建子进程,从而执行 Unix 系统命令 //下面这段代码实际就是把cmd这个参数传递的值,转化成前后没有空格的字符串,也就是版本号 function exec (cmd) { return require(‘child_process‘).execSync(cmd).toString().trim() } var versionRequirements = [ { name: ‘node‘, currentVersion: semver.clean(process.version), // 当前环境版本,使用semver插件把当前环境版本信息转化成规定格式,也就是 ‘ =v1.2.3 ‘ -> ‘1.2.3‘ 这种功能 versionRequirement: packageConfig.engines.node // 要求的版本,这是规定的pakage.json中engines选项的node版本信息 "node":">= 4.0.0" }, ] // npm环境中 if (shell.which(‘npm‘)) { versionRequirements.push({ name: ‘npm‘, currentVersion: exec(‘npm --version‘), // 执行方法得到版本号 versionRequirement: packageConfig.engines.npm // 要求的版本 }) } module.exports = function () { var warnings = [] for (var i = 0; i < versionRequirements.length; i++) { var mod = versionRequirements[i] //上面这个判断就是如果版本号不符合package.json文件中指定的版本号,就执行下面的代码 if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) { warnings.push(mod.name + ‘: ‘ + chalk.red(mod.currentVersion) + ‘ should be ‘ + chalk.green(mod.versionRequirement) ) } } if (warnings.length) { console.log(‘‘) console.log(chalk.yellow(‘To use this template, you must update following to modules:‘)) console.log() for (var i = 0; i < warnings.length; i++) { var warning = warnings[i] console.log(‘ ‘ + warning) } console.log() process.exit(1) } }
参考:http://www.cnblogs.com/ye-hcj/archive/2017/06.html
以上是关于vue-cli脚手架npm相关文件说明check-versions.js的主要内容,如果未能解决你的问题,请参考以下文章
vue-cli脚手架npm相关文件说明-2webpack.prod.conf.js
vue-cli脚手架npm相关文件说明config/index.js
vue-cli脚手架npm相关文件说明dev-server.js
vue-cli脚手架npm相关文件说明vue-loader.conf.js