Node实现获取命令行参数的方法及操作是什么
Admin 2022-11-12 群英技术资讯 962 次浏览
今天这篇给大家分享的知识是“Node实现获取命令行参数的方法及操作是什么”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“Node实现获取命令行参数的方法及操作是什么”文章能帮助大家解决问题。
在开发cli工具时,往往离不开获取指令中各种参数信息,接下来本文将带着你如何在Node.js中获取执行时的参数。
process是nodejs内置的一个对象,该对象提供了当前有关nodejs进程的信息。(例如获取当前进程id,执行平台等与当前执行进程相关的对象和方法)
node process文档
在该对象中,有一个arg属性,它可以获取当前node执行时传入各个参数数据。
我们创建一个index.js文件,先打印下process.args里面是什么东西
console.log(process.arg)
// node index.js
[
'D:\\software\\nodejs\\node.exe',
'D:\\project\\script\\src\\index.js'
]
登录后复制 从上面的输出结果,可以得到当前执行的node程序路径(也就是process.execPath返回值)和执行的文件(index.js)路径,我们像使用其他cli工具一样添加一些参数试试
node index.js name=zhangsan age=18
登录后复制 [
'D:\\software\\nodejs\\node.exe',
'D:\\project\\script\\src\\index.js',
'name=zhangsan',
'age=18'
]
登录后复制 可以看到我们传入的name参数与age参数也被获取到了
需要注意的是argv中的参数是通过空格来分割的
通常,我们会在命令行每个参数前面添加--字符,用来识别传入的各个参数。
例如在esbuild构建工具中
esbuild app.jsx --bundle --outfile=out.js
登录后复制 例如在vite构建工具中
vite --config my-config.js
登录后复制 修改一下上面的命令为
node index.js --name=zhangsan --age=18
登录后复制 将会得到如下输出结果
[
'D:\\software\\nodejs\\node.exe',
'D:\\project\\script\\src\\index.js',
'--name=zhangsan',
'--age=18'
]
登录后复制 从上面两个例子和官方文档中,我们可以得知argv的前两个参数都是固定的,在获取用户传入的参数我们需要process.argv.slice(2)一下,只获取从下标2开始的元素。 也即是
[
'--name=zhangsan',
'--age=18'
]
登录后复制 有了这些数据之后,我们需要再进一步解构里面的参数,将前面的--去除掉,把key=value改变成{key:value}方便我们在开发中进行参数获取。 最终我们得到了这样子的函数:
process.argv数组,并切片从下标2开始--开头,是则视为用户传入参数=区分出对应的key和value,其返回的是[key,value]Object.fromEntries转换为一个对象const arguments = process.argv.slice(2);
const params = Object.fromEntries(
arguments.reduce((pre, item) => {
if (item.startsWith("--")) {
return [...pre, item.slice(2).split("=")];
}
return pre;
}, []),
);
console.log(params)
// { name: 'zhangsan', age: '18' }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文详细讲解了Node.js进程管理之子进程,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
这篇文章给大家分享的是用JS实现重置功能的方法。对于重置的功能大家应该都不陌生,当网页填写的信息需要大量修改时,重置功能快速的重置页面,非常的方便。文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
这个插件可以用来在未使用组件库,没有自带好的校验规则时使用,进行表单校验,非常的实用,感兴趣的朋友可以参考下本文,了解该插件的使用方法
本文介绍的是关于React中this指向的内容,对于React中this指向问题下文有详细的介绍及解决方法供大家参考,需要的朋友可以了解看看,对大家学习React中this指向的内容有一定的参考价值。接下来我们就一起了解一下吧。
这篇文章主要给大家介绍了关于vue动态菜单、动态路由加载以及刷新踩坑的相关资料,踩的这些坑其实是挺常见的,大家可以看看,避免遇到的时候再踩到同样的坑,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008