npm_config_xxx

复制代码
// package.json

{ "scripts": { "log": "node index.js", } }

// index.js 
function logProcessEnv(key){ console.log(`process.env['${key}']`, process.env[key]); } 

logProcessEnv('npm_config_foo');

问题:

`npm run log` 和 `yarn log` 有没有区别?

首先这里读到了npm_config_foo变量,那么这个变量怎么来的呢?

比如:

npm config set foo=123

设置变量 foo 为123, 同时会往 .npmrc (用户主目录) 写入 foo=123 的配置信息 (永久)

同时,nodejs脚本可以通过process.env.npm_config_foo读取到123

还有其他设置么?有 --xxx=yyy 的形式,优先级最高

npm run task --foo=123

yarn task 不支持 --foo=123

.npmrc

除了用户主目录外,项目根目录也可以设置.npmrc文件,自行配置foo,优先级高于全局.npmrc

复制代码
foo=123

yarn config

会往.yarnc写配置,写法和 npm config有所区别,不能有等号,不然整串被当成一个整体,设置为true

复制代码
yarn config set foo 123

.yarnrc

内容格式也不一样

foo 123

使用注意

用yarn run和用npm run读取的配置不同(读的.npmrc还是.yarnrc?)

当运行npm run log 时,读取的npm_config_foo 来自.npmrc

当运行yarn log时,读取的npm_config_foo来自.yarnrc (如果没有配置在.yarnrc,会读取.npmrc)

结论:别混用npm和yarn

相关推荐
我是Superman丶9 分钟前
Element UI 表格某行突出悬浮效果
前端·javascript·vue.js
恋猫de小郭9 分钟前
你的代理归我了:AI 大模型恶意中间人攻击,钱包都被转走了
前端·人工智能·ai编程
xiaokuangren_37 分钟前
前端css颜色
前端·css
hoiii1871 小时前
C# 基于 LumiSoft 实现 SIP 客户端方案
前端·c#
anOnion1 小时前
构建无障碍组件之Meter Pattern
前端·html·交互设计
小码哥_常2 小时前
Spring Boot配置diff:解锁配置管理新姿势
前端
小码哥_常2 小时前
告别onActivityResult!Android数据回传的3大痛点与终极解决方案
前端
hhcccchh2 小时前
1.2 CSS 基础选择器、盒模型、flex 布局、grid 布局
前端·css·css3
专吃海绵宝宝菠萝屋的派大星3 小时前
使用Dify对接自己开发的mcp
java·服务器·前端