翼度科技»论坛 编程开发 JavaScript 查看内容

nvm & npm

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
nvm

nvm(Node Version Manager)是一个Node.js的版本管理器。
安装nvm

windows安装nvm

1. 下载nvm
下载地址:nvm-windows,下载 nvm-noinstall 或者 nvm-setup.exe
如果使用 nvm-noinstall 可以运行 install.cmd,会自动配置环境变量。
2. 配置环境变量
NVM_HOME: D:\program\nvm
NVM_SYMLINK: D:\program\nvm\nodejs
3. 将环境变量加入 PATH
%NVM_HOME%
%NVM_SYMLINK%
4. 修改setting.txt
如果没有,则在 NVM_HOME 目录下创建一个setting.txt(D:\program\nvm\setting.txt)
  1. root: D:\program\nvm
  2. path: D:\program\nvm\nodejs
  3. arch: 64
  4. proxy: none
  5. node_mirror: https://npmmirror.com/mirrors/node/
  6. npm_mirror: https://npmmirror.com/mirrors/npm/
复制代码
5. 验证是否安装成功
  1. # 查看版本号
  2. $ nvm v
  3. 1.1.9
复制代码
 
mac安装nvm
  1. # 安装nvm
  2. $ brew install nvm
  3. # 查看包信息
  4. $ brew info nvm
  5. # 创建目录
  6. $ mkdir ~/.nvm
  7. # 修改~/.bash_profile和~/.zshrc
  8. export NVM_DIR="$HOME/.nvm"
  9.   [ -s "/opt/homebrew/opt/nvm/nvm.sh" ] && \. "/opt/homebrew/opt/nvm/nvm.sh"  # This loads nvm
  10.   [ -s "/opt/homebrew/opt/nvm/etc/bash_completion.d/nvm" ] && \. "/opt/homebrew/opt/nvm/etc/bash_completion.d/nvm"
  11. # 查看版本号
  12. $ nvm -v
  13. 0.39.2
复制代码
 
linux安装nvm
  1. # 使用curl安装nvm
  2. $ curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash
  3. # 使用wget安装nvm
  4. $ wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash
  5. # 修改~/.bash_profile和~/.zshrc
  6. export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")"
  7. [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
  8. $ source ~/.bashrc
  9. $ source ~/.zshrc
复制代码
 
安装node
  1. # 查看可以安装的node版本 http://nodejs.org/dist
  2. $ nvm list available
  3. # 查看已经安装的node版本
  4. $ nvm list
  5. $ nvm ls
  6. # 安装指定版本的node
  7. $ nvm install 18.20.1
  8. # mac或者linux手动安装node,可以将node安装包解压后放在~/.nvm/versions/node目录下
  9. $ ls ~/.nvm/versions/node
  10. v12.22.1  v14.17.0  v18.20.1
  11. # 切换到指定版本的node(windows可能需要使用管理员身份运行)
  12. $ nvm use 18.20.1
  13. # 查看node版本
  14. $ node -v
复制代码
 
nvm命令
  1. # mac和linux的node安装目录在~/.nvm/versions/node,windows可以修改node安装目录
  2. # 查看node安装目录(不同版本的node都会安装到这个目录下,默认和nvm同一个目录)
  3. $ nvm root
  4. # 修改node安装目录
  5. $ nvm root D:\program\nvm
  6. # 卸载node
  7. $ nvm uninstall 18.20.1
  8. # 安装最新版本node
  9. $ nvm install latest
  10. # 查看当前node版本
  11. $ nvm current
  12. # 给版本指定别名
  13. $ nvm alias test 18.20.1
  14. # 删除别名
  15. $ nvm unalias test
  16. # 清空nvm本地缓存
  17. $ nvm cache clear
复制代码
 
npm

npm(Node Package Manager)是一个Node.js包管理器。
帮助文档

npm官方文档:https://docs.npmjs.com/cli/
  1. # 查看帮助
  2. $ npm help
  3. # 查看指定命令的帮助
  4. $ npm config -h
  5. $ npm install -h
复制代码
 
配置npm
  1. # 查看npm版本
  2. $ npm --version
  3. $ npm -v
  4. # 查看所有配置
  5. $ npm config list -l
  6. $ npm config ls -l
  7. # 查看用户配置(用户的配置文件在~\.npmrc)
  8. $ npm config list
  9. $ npm config ls
  10. # 查看prefix和cache的配置
  11. # prefix用于存放npm全局安装的包,cache用于缓存已下载的包
  12. $ npm config get prefix cache
  13. # 配置npm全局安装目录(默认安装在当前npm目录下,如果切换了npm会导致之前的全局安装无法使用)
  14. $ npm config set prefix=D:\program\nvm\node-global
  15. $ npm config set cache=D:\program\nvm\node-global-cache
  16. # windows要配置环境变量 NPM_HOME: D:\program\nvm\node-global
  17. # 设置镜像
  18. $ npm config set registry=https://registry.npmmirror.com/
  19. # 删除配置项
  20. $ npm config delete registry
复制代码
 
.npmrc配置文件:除了使用命令配置npm,也可以直接修改~/.npmrc文件。
  1. registry=https://registry.npmmirror.com/
  2. prefix=D:\program\nvm\node-global
  3. cache=D:\program\nvm\node-global-cache
  4. # 设置某些包的镜像站点
  5. chromedriver_cdnurl=https://npmmirror.com/mirrors/chromedriver/
  6. sass_binary_site=https://npmmirror.com/mirrors/node-sass/
  7. geckodriver_cdnurl=https://npmmirror.com/mirrors/geckodriver/
  8. # phantomjs不再维护
  9. phantomjs_cdnurl=https://bitbucket.org/ariya/phantomjs/downloads
复制代码
 
npm命令

初始化项目
  1. # 初始化(创建package.json文件,会提示输入一系列信息)
  2. $ npm init
  3. # 直接生成package.json文件
  4. $ npm init -y
复制代码
 
package.json:https://docs.npmjs.com/cli/configuring-npm/package-json
  1. {
  2.   "name": "npm-test",
  3.   "version": "1.0.0",
  4.   "keywords": ["package manager"],
  5.   "description": "a package manager for JavaScript",
  6.   "homepage": "https://github.com/npm/cli#readme",
  7.   "author": "Barney Rubble <b@rubble.com>",
  8.   "repository": {
  9.     "type": "git",
  10.     "url": "https://github.com/npm/cli.git"
  11.   },
  12.   "main": "dist/index.js",
  13.   "scripts": {
  14.     "test": "echo "Error: no test specified" && exit 1"
  15.   },
  16.   "dependencies": {
  17.     "jquery": "^3.7.1"
  18.   },
  19.   "license": "ISC"
  20. }
复制代码
字段名说明
name包名
version包的版本号
keywords关键字
description项目的描述
homepage项目的网站或文档页面的URL
author项目的作者,一个人
contributors项目的其他贡献者,数组
repository项目代码存放的地方的类型,git或svn
main程序的主入口文件,require(模块名)会加载这个文件
scripts项目的脚本命令
dependencies依赖包(用于生产环境)
devDependencies依赖包(用于开发环境)
 
安装依赖
  1. # 安装指定的包
  2. $ npm install jquery
  3. # 将包安装到全局目录
  4. $ npm install -g jquery
  5. # 安装指定版本的包
  6. $ npm install jquery@3.0.0
  7. # 安装包并将其添加到package.json的dependencies中(用于生产环境)
  8. $ npm install --save jquery
  9. $ npm install -S jquery
  10. # 安装包并将其添加到package.json的devDependencies中(用于开发环境)
  11. $ npm install --save-dev jquery
  12. $ npm install -D jquery
  13. # 安装本地包(使用npm pack将项目打包成.tgz文件,然后拷贝到另一个项目中安装)
  14. $ npm install mytest-1.0.0.tgz
  15. {
  16.   "dependencies": {
  17.     "mytest": "file:mytest-1.0.0.tgz"
  18.   }
  19. }
复制代码
 
使用别名

可以使用npm的别名来安装同一个包的不同版本。
  1. # npm install <alias>@npm:<name>
  2. # 安装lodash@3.0.0
  3. $ npm install lodash3@npm:lodash@3
  4. # 安装lodash@4.0.0
  5. $ npm install lodash4@npm:lodash@4
复制代码
package.json:
  1. {
  2.   "dependencies": {
  3.     "lodash3": "npm:lodash@^3.10.1",
  4.     "lodash4": "npm:lodash@^4.17.21"
  5.   }
  6. }
复制代码
  1. // 使用不同版本的lodash
  2. const lodash3 = require('lodash3');
  3. const lodash4 = require('lodash4');
  4. console.log(lodash3.VERSION); // 3.10.1
  5. console.log(lodash4.VERSION); // 4.17.21
复制代码
 
查看依赖
  1. # 查看当前目录下所有依赖的版本
  2. $ npm list
  3. # 查看当前目录下某个依赖的版本
  4. $ npm list jquery
复制代码
 
更新依赖
  1. # 将指定包更新到最新版本(package.json中指定的版本范围内的最新版本)
  2. # 会更新package-lock.json中的版本,但是不会更新package.json
  3. $ npm update jquery
  4. # 更新package.json中列出的所有包到最新版本
  5. $ npm update
复制代码
 
删除依赖
  1. # 从node_modules和package.json中删除包
  2. $ npm uninstall jquery
复制代码
 
查询包信息
  1. # 查看npm服务器上的所有jquery版本
  2. $ npm view jquery versions
  3. # 查看npm服务器上jquery的信息
  4. $ npm view jquery
  5. # 在npm仓库中搜索包
  6. $ npm search jquery
复制代码
 
发布包
  1. # 登录npm账号
  2. $ npm login
  3. # 查看当前登陆用户
  4. $ npm whoami
  5. # 退出登录
  6. $ npm logout
  7. # 发布包
  8. $ npm publish
  9. # 撤销发布过的某个版本代码
  10. $ npm unpublish <package>@<version>
  11. # 删除整个包
  12. $ npm unpublish <package> --force
  13. # 清空npm本地缓存(如果开发者使用相同版本号发布新代码,可以避免因版本号未变而无法获取最新代码)
  14. $ npm cache clear
复制代码
 
  1. # 将项目打成一个.tgz文件(这个文件可以用来发布到npm或者在另一个项目中本地安装)
  2. $ npm pack
  3. # 将.tgz文件发布到npm
  4. $ npm publish xxx.tgz
复制代码
 
peerDependencies
  1. $ npm install -S react react-router
复制代码
react-router的package.json:
  1. {
  2.   "peerDependencies": {
  3.     "react": ">=16.8"
  4.   }
  5. }
复制代码
peerDependencies 说明 react-router 依赖 react,但不是将 react 作为 react-router 的子依赖安装,而是使用项目中的 react。
  1. # react-router下没有react
  2. $ tree -d node_modules
  3. node_modules
  4. ├── react
  5. │   ├── cjs
  6. │   └── umd
  7. └── react-router
  8.     └── dist
  9.         ├── lib
  10.         └── umd
复制代码
 
参考资料

npm官网
npmmirror 镜像站
 

来源:https://www.cnblogs.com/vera0119/p/18111846
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具