npm环境搭建

npm是什么

npm是前端的包管理工具,类似于后端的maven。现在npm已经集成到nodeJs中,安装好nodeJs就可以安装好npm了。

npm初始配置

一般下载好nodeJs后要对npm进行一些初始化配置。

修改npm的镜像源

npm默认的镜像源是https://registry.npmjs.org/,这个服务器是在国外的,网速一般会比较慢,所以可以修改成我们国内的npm镜像源。

shell 复制代码
# 查看npm当前镜像源
npm config get registry
# 设置npm的镜像源
npm config set registry https://registry.npmjs.org/

# 国内的镜像源
# 腾讯
npm config set registry http://mirrors.cloud.tencent.com/npm/
# 华为
npm config set registry https://mirrors.huaweicloud.com/repository/npm/

修改npm本地仓库的位置

npm在本地有两个仓库,一个是npm-cache,另一个是npm-local

npm-cache 本地缓存

npm-cache是npm的缓存路径,用于存储已经下载的包文件。当您使用npm install安装包时,npm会将下载的包存储在npm-cache中,以便在之后的安装过程中重复使用,避免重复下载。这有助于加快安装速度并减少网络流量。
npm-local 本地全局仓库

npm-local是npm的全局仓库路径,即安装一些通用的工具类,如vue、typescript。用npm install vue -g安装,-g表示global,安装到npm-local中。通常要把该路径加入到环境变量中,这样就可以在命令行直接使用安装好的命令。

shell 复制代码
# npm本地仓库默认在C盘,这很不友好
# 修改npm-local本地路径
npm config set prefix D:\npm_repository\npm-local
npm config get prefix
# 修改npm-cache本地路径
npm config set cache prefix D:\npm_repository\npm-cache
npm config get cache

# 或者通过下面命令查看npm的所有配置
npm config list

npm install、npm install --save与npm install --save-dev区别

npm5.0.0之前,npm install X

npm install:会把X包安装到node_modules目录中;不会修改package.json,所以之后别人拉取最新的代码后运行npm install,不会安装X

npm install --save:会把X包安装到node_modules目录中,并且修改package.json中的dependencies,所以之后别人拉取最新的代码后运行npm install,会安装X

npm install --save-dev:会把X包安装到node_modules目录中,并且修改package.json中的devDependencies,所以之后别人拉取最新的代码后运行npm install,会安装X,但打包的时候不会包含该依赖
npm5.0.0之后(包括npm5.0.0)

npm install和npm install --save是等价的,即默认就是安装依赖并且修改package.json中的dependencies。

shell 复制代码
npm install --save 可以简写为 npm i -S
npm install --save-dev 可以简写为 npm i -D
相关推荐
章丸丸2 分钟前
Tube - Studio Videos
前端·后端
因吹斯汀1 小时前
一饭封神:当AI厨神遇上你的冰箱,八大菜系大师在线battle!
前端·vue.js·ai编程
再学一点就睡1 小时前
NATAPP 内网穿透指南:让本地项目轻松 “走出去”
前端
拜无忧1 小时前
2025最新React项目架构指南:从零到一,为前端小白打造
前端·react.js·typescript
稻草人不怕疼1 小时前
记一次从“按钮点不动”到“窗口派发缺失”的排查过程
前端
前端小哲1 小时前
MCP从入门到实战
node.js·ai编程
irving同学462381 小时前
TypeORM 列装饰器完整总结
前端·后端·nestjs
彭于晏爱编程1 小时前
你真的了解 Map、Set 嘛
前端
崔璨1 小时前
详解Vue3的响应式系统
前端·vue.js
摸鱼的鱼lv1 小时前
🔥 Vue.js组件通信全攻略:从父子传值到全局状态管理,一篇搞定所有场景!🚀
前端·vue.js