前端开发系列079-Node篇之npm+
npm(node package manager
) Node的包管理工具,我们可以利用该工具来搜索、下载、安装、卸载和升级包,在下载和安装Node的时候npm
会捆绑在一起默认安装。
nrm(npm registry manager
) Node的镜像源管理工具,如果访问国外的包速度太慢,那么可以考虑利用nrm
来切换镜像源。
nvm(node version management
) 是Mac下的用来管理不同版本node
的工具,如果是管理 Windows系统,可以使用nvmw
或nvm-windows
。
npx 从5.2版开始,npm
增加了 npx
,该工具主要用来执行包(二进制文件)。
npm init 交互创建package.json文件
npm init -y 默认创建package.json文件
npm --help 查看帮助信息
npm --version 查看版本信息,别名为-v
npm cache clean 清除缓存
npm cache verify 验证缓存
npm cache clean --force 强制清除缓存
npm search xx 搜索关键字相关的包
npm view xx 查看指定包最新版本的信息(版本、作者、地址等)
npm info xx 同上,别名view、v、info、和show
npm ls 列出本地(当前项目)安装的所有包
npm ls -g 列出全局安装的所有包
npm list -g --depth 0 列出全局安装的所有包 控制显示层级
npm i xx 安装指定的包(本地安装) i=== install
npm install xx 安装指定的包(本地安装-项目依赖) 默认--save === -S
npm install xx -g 安装指定的包(全局安装)
npm install xx --save-dev 安装指定的包(本地安装-开发依赖) --save-dev === -D
npm install xx -D 安装指定的包(本地安装-开发依赖)
npm uninstall xx 卸载指定的包,别名un, unlink, remove, rm, r
npm install 根据package.json文件来安装所有需要的包
npm config ls 查看配置信息 ls === list
npm config ls -l 查看所有的配置信息
npm config set xx 设置配置项 config === c
npm config set registry=https://registry.npm.taobao.org/ 切换镜像源为taobao镜像
npm config get registry 查看当前镜像源
npm config get home 查看当前主页(home)地址
npm update xx 更新指定的包
npm update 更新所有项目依赖包 等价于npm update --save
npm update --save-dev 更新所有生产依赖包
npm update -g 更新全局包
npm adduser 注册用户
npm publish 发布模块
npm root 查看本地项目中包的安装路径
npm root -g 查看全局包的安装路径
npm docs jquery 打开查看指定包的官网(官方文档)
npm run <command> 执行命令(参考package.json文件中scripts中的配置)
npm pack 打包
npm link 链接本地包
npm unlink 卸载本地包
env 查看环境变量
nrm --help 查看帮助信息
nrm ls 列出所有的镜像源
nrm current 列出当前使用的镜像源
nrm use xx 切换并使用某个特定的镜像源 等同于 npm config set registry=
nrm add wen http://wendingding.com 添加新的镜像源 wen是名称,后面跟的是URL路径
nrm del wen 删除指定镜像源
nrm test taobao 测试指定镜像源的速度
参考:NVM的GitHub官方仓库
参考:nvm-windows官方仓库
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.6/install.sh | bash
通过curl来安装nvm,安装完毕后会自动配置环境变量,通过下面的命令来查看.bash_profile
文件,可以看到配置文件中已经新增加了环境变量的配置。
cd ~ 切换到根目录
open .bash_profile 打开配置文件
# 下面列出的是.bash_profile文件的拟任
# Add Visual Studio Code (code)
export PATH="$PATH:/Applications/Visual Studio Code.app/Contents/Resources/app/bin"
export PATH="/usr/local/opt/openssl/bin:$PATH"
export PATH=${PATH}:/usr/local/MongoDB/bin
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm ..
我们还需要通过下面的命令来更新配置过的环境变量,然后查看nvm
的版本信息如果能够正确打印版本则安装成功。
source .bash_profile 更新环境变量
command -v nvm 如果打印nvm则说明安装成功
nvm --version 打印版本信息 0.33.6
nvm --help 查看帮助信息
nvm --version 查看版本信息
nvm install [-s] <version> 安装指定版本的包
nvm install node 安装最新的版本
nvm install --lts 安装最新的稳定版本
nvm uninstall <version> 卸载
nvm uninstall --lts 卸载最新的稳定版本
nvm ls 查看本地安装的Node版本
nvm ls-remote 列出可安装的所有远程版本
nvm use 版本号 切换Node版本
nvm current 查看当前版本
npx
工具想要解决的主要问题是调用项目内部安装的模块。
一般情况下我们调用项目内部安装的模块,只能在项目脚本和package.json
的scripts
字段里面配置(通过npm run xxx
的方式调用)。如果要通过命令行调用则会比较麻烦,我们可以做个对比:
$ npm install mocha --save-dev 安装开发依赖
# [1] 通过npm的方式来执行
$ cd node_modules/.bin/ 切换到本地项目.bin目录中
$ mocha --version 执行对应的模块
# [2] 通过配置package.json文件的script字段来执行
# 配置项:"mocha":"./node_modules/.bin/mocha --version"
$ npm run mocha
# [3] 通过npx的方式来执行
$ npx mocha --version 执行mocha模块
npx
不需要全局安装依赖包的情况下,直接运行命令来临时安装-使用-写在,整个操作一气呵成而且运行后不会污染全局环境。比如我们初始化一个项目的时候,npx create-react-app my-react-app
指令,会将create-react-app
下载到一个临时目录,使用以后再删除,每次运行这个命令,都会重新下载依赖包运行后删除。
如果我们需要检查某个文件的媒体类型(mime
类型),可以通过mime
这个包来实现。
$ npx mime index.js
npx: 1 安装成功,用时 1.994 秒
application/javascript
npx
在使用的时候感觉比较像npm run
,但是更加灵活和方便,它的原理就是运行的时候会去node_modules/.bin
路径检查npx
后的命令是否存在,存在则执行,如果找不到,那么就继续去环境变量$PATH
里面查找,存在则执行,如果还是找不到,那么就会自动下载依赖包的最新版本到临时目录,然后再运行命令,运行完之后把该包删除。
前端开发系列079-Node篇之npm+的更多相关文章
- openlayers5-webpack 入门开发系列一初探篇(附源码下载)
前言 openlayers5-webpack 入门开发系列环境知识点了解: node 安装包下载webpack 打包管理工具需要依赖 node 环境,所以 node 安装包必须安装,上面链接是官网下载 ...
- leaflet-webpack 入门开发系列一初探篇(附源码下载)
前言 leaflet-webpack 入门开发系列环境知识点了解: node 安装包下载webpack 打包管理工具需要依赖 node 环境,所以 node 安装包必须安装,上面链接是官网下载地址 w ...
- 【Windows10 IoT开发系列】配置篇
原文:[Windows10 IoT开发系列]配置篇 Windows10 For IoT是Windows 10家族的一个新星,其针对不同平台拥有不同的版本.而其最重要的一个版本是运行在Raspberry ...
- cesium-webpack 入门开发系列一初探篇(附源码下载)
前言 cesium-webpack 入门开发系列环境知识点了解: node 安装包下载webpack 打包管理工具需要依赖 node 环境,所以 node 安装包必须安装,上面链接是官网下载地址 we ...
- 旨在脱离后端环境的前端开发套件 - IDT Server篇
IDT,一个基于Nodejs的,旨在脱离后端环境的前端开发套件,目的就是能让前端开发完全脱离后端的环境,无论后端是什么模板引擎(主流),都能应付自如. IDT主要包括两大部分:Server + Bui ...
- [置顶]【实用 .NET Core开发系列】- 导航篇
前言 此系列从出发点来看,是 上个系列的续篇, 上个系列因为后面工作的原因,后面几篇没有写完,后来.NET Core出来之后,注意力就转移到了.NET Core上,所以再也就没有继续下去,此是原因之一 ...
- 前端开发【第2篇:CSS】
鸡血 样式的属性多达几千个,但别担心,按照80-20原则,常用的也就几十个,你完全可以掌握它. Css初识 HTML的诞生 早期只有HTML的时候为了让HTML更美观一点,当时页面的开发者会把颜色写到 ...
- openlayers4 入门开发系列之风场图篇
前言 openlayers4 官网的 api 文档介绍地址 openlayers4 api,里面详细的介绍 openlayers4 各个类的介绍,还有就是在线例子:openlayers4 官网在线例子 ...
- openlayers4 入门开发系列之热力图篇(附源码下载)
前言 openlayers4 官网的 api 文档介绍地址 openlayers4 api,里面详细的介绍 openlayers4 各个类的介绍,还有就是在线例子:openlayers4 官网在线例子 ...
- Android Metro风格的Launcher开发系列第三篇
前言: 各位小伙伴,又到了每周更新文章了时候了,本来是周日能发出来呢,这不是赶上清明节吗,女王大人发话了,清明节前两天半陪她玩,只留给我周一下午半天时间写博客,哪里有女王哪里就有压迫呀有木有!好了闲话 ...
随机推荐
- 不同数据库Oracle、PostgreSQL、Vertical、Mysql常用操作
不同数据库Oracle.PostgreSQL.Vertical.Mysql常用操作 授权语句用于管理数据库用户的权限,常见的授权语句如下: 1.授权用户对表的SELECT权限 GRANT SELECT ...
- zk源码—4.会话的实现原理
大纲 1.创建会话 (1)客户端的会话状态 (2)服务端的会话创建 (3)会话ID的初始化实现 (4)设置的会话超时时间没生效的原因 2.分桶策略和会话管理 (1)分桶策略和过期队列 (2)会话激活 ...
- Unity3D教程:次表面散射的简单实现
次表面散射指的是光线射入半透明材质,在内部发生散射后再透射出来的光线传播过程,考虑到有些项目会需要使用次表面散射,下面就给大家介绍下在Unity3D中次表面散射的简单实现,希望可以帮到大家. 一.前言 ...
- eolinker请求参数:提交参数JSON转换格式不正确的解决方法
当某个接口的提交参数类型为"array"时,该接口被自动化测试调用会转换成text类型. 导致执行测试的时候,整个参数转化json格式不正确 解决方法是在 格式不正确的项后面 配 ...
- SAP HANA使用命令行快速导出导入
楔子 今天折腾了接近一下午,就为了使用SAP HANA自带的命令行工具来导出数据备份. SAP HANA(后续简称Hana)是内存数据库,性能这一方面上还真没怕过谁. 由于SAP HANA提供了Han ...
- 为什么 Java 8 移除了永久代(PermGen)并引入了元空间(Metaspace)?
为什么 Java 8 移除了永久代(PermGen)并引入了元空间(Metaspace)? 在 Java 8 中,JVM 移除了 永久代(PermGen)并引入了 元空间(Metaspace),这一改 ...
- 查询相册更加mysql 查询
接到一个项目项目案例相册是这种结构 大佬建议 sql 查询 groip 进行时间统计今天 field根据mysql 时间查询进行统计 今天多少条 新增多少条相册 计算天数 $lists = Album ...
- 聊聊@Autowired与@Resource的区别
1. 前言 从事过很多家公司,见过很多项目,发现@Autowired和@Resource的使用都是一样的乱, 一个项目中有使用@Autowired的,有使用@Resource的, 甚至有的类中一会儿使 ...
- 信息资源管理综合题之“QS认证是什么标准 和 如何证明已通过QS 和 可否建立自己的生产标准”
一.案例:自2003年起,我国开始对大米.食用植物油等食品进行了一种新的管理制度:食品质量安全市场准入制度,到目前为止,所有经过加工的食品,生产地址在国内的产品全部必须申请生产许可证,经过强制性的检验 ...
- SpringBoot发布webservice服务并调用(hutool yyds)
作者:故事我忘了¢个人微信公众号:程序猿的月光宝盒 目录 前言 开干 1.涉及技术点 2.整体项目结构 3.Provider 发布Ws服务端 首先,肯定要修改pom文件 依赖加上 3.0 因为用对象的 ...