首页 技术 正文
技术 2022年11月9日
0 收藏 766 点赞 4,077 浏览 952 个字

首先,我们看到在 package.json 中有 scripts 的定义:

“scripts”: {
“serve”: “vue-cli-service serve”,
“build”: “vue-cli-service build”,
“lint”: “vue-cli-service lint”
}

我们看到 serve 和 build 其实多是依托的 vue-cli-service

之前我们提到过了通过 api.registerCommand 来注册命令的:

比如在 cli-service/lib/commands/serve.js


module.exports = (api, options) => {
api.registerCommand('serve', {
// ...
}, async function serve (args) {
})
}

我们看一下 cli-service/lib/PluginAPI.js 文件:


class PluginAPI {
constructor (id, service) {
this.id = id
this.service = service
}
}

函数 registerCommand 会设置 service.commands

接受 3 个参数:

  • name
  • opts
  • fn

registerCommand (name, opts, fn) {
if (typeof opts === 'function') {
fn = opts
opts = null
}
this.service.commands[name] = { fn, opts: opts || {}}
}

我们再看一下 cli-service/bin/vue-cli-service.js


service.run(command, args, rawArgv).catch(err => {
error(err)
process.exit(1)
})

cli-service/lib/Service.js 会调用 run 方法:


async run (name, args = {}, rawArgv = []) {
}

里面会从 commands 里面取:


let command = this.commands[name]

最终执行它里面的 fn


const { fn } = command
return fn(args, rawArgv)

来源:https://segmentfault.com/a/1190000016253182

上一篇: 2-1 Numpy-数组
下一篇: Linux之源码包
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,487
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,903
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,736
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,487
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,127
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,289