【nodejs】npm与包

news2024/11/8 2:44:02

1、什么是包

Node.js中的第三方模块又叫包

2、包的来源

由第三方个人或团队开发出来的,免费供所有人使用

3、为什么需要包

由于Node.js的内置模块仅提供了一些底层的API,导致在基于内置模块进行项目开发时,效率很低。
包是基于内置模块封装出来的,提供了更高级、更方便的API,极大的提高了开发效率。

4、从哪里下载包

搜索包:https://www.npmjs.com
下载包:https://registry.npmjs.org 服务器

5、安装包

npm install 包的完整名称

初次装包完成后,在项目文件夹下多了叫做 node_modules的文件夹和 package-lock.json的配置文件

node_modules:用来存放所有安装到项目中的包。require()导入第三方包时,就是从这个目录中查找并加载包。
package-lock.json:用来记录 node_modules目录下每个包的下载信息,例如包的名字、版本号、下载地址等。

默认情况下使用npm install命令安装包的时候会自动安装最新版本的包,如果需要安装指定版本的,可以在包名后面用@符号指定具体的版本

6、包的语义化版本规范

包的版本号是以“点分十进制”形式进行定义的,总共有三位数字,例如:2.22.0

第1位:大版本(发生了底层重构)
第2位:功能版本(新增了功能)
第3位:Bug修复版本(对bug进行了修复)

版本号提升的规则:只要前面的版本号增长了,则后面的版本号归零

7、包管理配置文件

在项目根目录中,创建一个叫package.json的配置文件,即用来记录项目中安装了哪些包。从而方便剔除node_modules目录之后,在团队成员之间共享项目的源代码。

注意:在项目开发中,要把node_modules文件夹添加到.gitignore忽略文件中

1、快速创建 package.json
npm init -y

注意:上述命名只能在英文的目录下成功运行,所以项目文件夹的名称要使用英文,不要使用中文,不能出现空格

在这里插入图片描述

运行 npm install 命令安装包的时候,npm 包管理工具会自动把包的名称和版本号记录到package.json中。

2、dependencies节点

用来记录使用 npm install 命令安装了哪些包

3、一次性安装所有的包
npm install(或 npm i)

执行 npm install 命令时,npm 包管理工具会先读取 package.json 中的 dependencies 节点,读取到记录的所有依赖包名称和版本号之后,npm 包管理工具会把这些包一次性下载到项目中。

4、卸载包
npm uninstall 包名

npm uninstall 命令执行成功后,会把卸载的包自动从 package.jsondependencies 中移除掉。

5、devDependencies节点

如果某些包只在项目开发阶段会用到,在项目上线之后不会用到,则建议把这些包记录到devDependencies节点中。如果某些包在开发项目上线后都需要用到,则建议把这些包记录到dependencies中。

npm install 包名 --save-dev

简写:

npm i 包名 -D
6、解决包下载速度慢的问题

1、原因:在使用 npm 下包的时候,默认从国外的服务器上进行下载,此时网络数据的传输需要经过漫长的海底光缆,因此下载包速度会很慢。

2、淘宝NPM镜像服务器:淘宝在国内搭建了一个服务器,专门把从国外官方服务器上的包同步到国内的服务器,然后在国内提供下包的服务,从而极大的提高了下包的速度。
3、切换npm的下包镜像源:

# 查看当前的下包镜像源
npm config get registry
# 将下包的镜像源切换成淘宝镜像源
npm config set registry=https://registry.npm.taobao.org/
# 检查镜像源是否下载成功
npm config get registry

4、nrm

为了更方便的切换下包的镜像源,可以安装 nrm小工具,利用 nrm 提供的终端命令,可以快速查看和切换下包的镜像源

# 安装
npm i nrm -g
# 查看所有可用的镜像源
nrm ls
# 将下包的镜像源切为taobao镜像
nrm use taobao

在这里插入图片描述

8、包的分类

1、项目包

被安装到项目的 node_modules 目录中的包都是项目包

① 开发依赖包(被记录到 devDependencies节点中的包,只会在开发期间用到)

② 核心依赖包(被记录到 dependencies节点中的包,在开发期间和项目上线后都会用到)

# 开发依赖包
npm i 包名 -D 
# 核心依赖包
npm i 包名
2、全局包

在执行 npm install 命令时,如果提供了 -g 参数,则会把包安装为全局包,全局包会被安装到 C:\Users\用户目录\AppData\Roaming\npm\node_modules目录下

# 全局安装指定的包
npm i 包名 -g
# 卸载全局安装的包
npm uninstall 包名 -g

注意:
① 只有工具性质的包,才有全局安装的必要性。因为它们提供了好用的终端命令。
②判断某个包是否需要全局安装后才能使用,可以参考官方提供的使用说明即可。

9、规范的包结构

一个规范的包,它的组成结构必须符合以下3点要求

①包必须以单独的目录而存在
②包的顶级目录下必须包含package.json这个包管理配置文件
③package.json中必须包含nameversionmain这三个属性,分别代表包名版本号入口

10、开发属于自己的包

1、需要实现的功能

① 格式化日期
② 转义 HTML 中的特殊字符
③ 还原 HTML 中的特殊字符

2、初始化包的基本结构

① 新建 ithanxu-tools 文件夹,作为包的根目录
②在ithanxu-tools文件夹中新建三个文件:package.json(包管理配置文件)、index.js(包的入口文件)、README.md(说明文档)

在这里插入图片描述

3、初始化 package.json
{
  "name": "ithanxu-tools",
  "version": "1.0.0",
  "main": "index.js",
  "description": "提供了格式化时间、HTMLEscape相关的功能",
  "keywords": ["ithanxu","dateFormat","escape"],
  "license": "ISC"
}
4、在dateFormat.js中定义格式化时间的方法
// 定义格式化时间的函数
function dateFormat(dataStr) {
  const dt = new Date(dataStr)
  const y = dt.getFullYear()
  const m = padZero(dt.getMonth() + 1)
  const d = padZero(dt.getDate())
  const hh = padZero(dt.getHours())
  const mm = padZero(dt.getMinutes())
  const ss = padZero(dt.getSeconds())
  return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
}

// 定义补零函数
function padZero(n) {
  return n > 9 ? n : '0' + n
}

// 向外暴露需要的成员
module.exports = {
  dateFormat
}
5、在htmlEscape.js中定义转义HTML和还原HTML的方法
// 定义转义HTML字符的函数
function htmlEscape(htmlStr) {
  return htmlStr.replace(/<|>|"|&/g,(match) => {
    switch (match) {
      case '<':
        return '&lt;'
      case '>':
        return '&gt;'
      case '"':
        return '&quot;'
      case '&':
        return '&amp;'
    }
  })
}

// 定义还原HTML字符的函数
function htmlUnEscape(str) {
  return str.replace(/&lt;|&gt;|&quot;|&amp;/g,(match) => {
    switch(match) {
      case '&lt;':
        return '<'
      case '&gt;':
        return '>'
      case '&quot;':
        return '"'
      case '&amp;':
        return '&'
    }
  })
}

// 向外暴露需要的成员
module.exports = {
  htmlEscape,
  htmlUnEscape
}
6、在index.js中导入两个模块,得到需要向外共享的方法,再把对应的方法共享出去
const date = require('./dateFormat')
const escape = require('./htmlEscape')
// 向外暴露需要的成员
module.exports = {
  ...date,
  ...escape
}
7、编写包的使用说明文档

包含:安装方式、导入方式、格式化时间、转义HTML中的特殊字符、还原HTML中的特殊字符、开源协议

(1)安装

npm install ithanxu-tools

(2)导入

const ithanxu = require('ithanxu-tools')

(3)格式化时间

const dtStr = ithanxu.dateFormat(new Date())

(4)转义HTML中的特殊字符

// 定义要转化的HTML字符串
const htmlStr = '<h1 title="abc">这是h1标签<span>123&nbsp;</span></h1>'
// 调用htmlEscape方法进行转化
const str = ithanxu.htmlEscape(htmlStr)
// 转化的结果:&lt;h1 title=&quot;abc&quot;&gt;这是h1标签&lt;span&gt;123&amp;nbsp;&lt;/span&gt;&lt;/h1&gt;
console.log(str)

(5)还原HTML中的特殊字符

// 调用htmlUnEscape方法进行还原
const str2 = ithanxu.htmlEscape(str)
// 转化的结果:<h1 title="abc">这是h1标签<span>123&nbsp;</span></h1>
console.log(str2)

(6)开源协议

ISC
8、发布包
1、注册npm账号

① 访问 https://www.npmjs.com/网站,点击sign up按钮进入注册页面

在这里插入图片描述
② 填写账号相关信息

在这里插入图片描述
③ 点击 Create an Account 按钮,注册账号
④登录邮箱,点击验证链接,进行账号的验证
在这里插入图片描述

2、登录npm账号

在终端执行 npm login 命令,依次输入用户名、密码、邮箱后即可登录成功

注意:在运行 npm login 命令之前,必须先把下包的服务器地址切换为 npm 的官方服务器,否则会导致发布包失败

在这里插入图片描述

3、把包发布到npm上

将终端切换到包的根目录后,运行 npm publish 命令,即可将包发布到npm上(注意:包名不能雷同

在这里插入图片描述

此时在npm上就上传了包:
在这里插入图片描述

4、删除已发布的包

运行 npm unpublish 包名 --force 命令,即可从 npm 删除已发布的包

注意:

① npm unpublish 命令只能删除 72小时以内发布的包
② npm unpublish 删除的包,在24小时内不允许重复发布
③ 发布包的时候要慎重,尽量不要往 npm 上发布没有意义的包

在这里插入图片描述
此时 npm 上包被删除
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/141840.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

杨校老师课堂之IntellJ IDEA的使用技巧

下载地址&#xff1a; https://www.jetbrains.com.cn/idea/download/#sectionwindows 一、常规操作 1、忽略大小写&#xff0c;进行提示 2、启用Idea时&#xff0c;默认不再打开上次项目 3、设置主题 4、设置默认的字体 5、修改类头的文档注释信息 6、设置项目文件编码 7、统一…

electron与jquery起冲突,使用jquery报错解决方法

问题原因&#xff1a;Electron 为了整合 Node.js&#xff0c;会在 DOM 加入 module、exports、require 等模块和函数&#xff0c;和jQuery、RequireJS、Meteor、AngularJS 等发生冲突。 暴力解决方法&#xff1a;去除node功能加持&#xff0c;在加载browserWindow或者browserVi…

C++:闭包:闭包Closure理解

一&#xff1a;什么是闭包 闭包有很多定义&#xff0c;一种说法是&#xff1a;闭包是带有上下文的函数&#xff0c;说白了&#xff0c;就是有状态的函数&#xff0c;这其实就是一个类&#xff0c;换个名字而已。 一个函数&#xff0c;带上一个状态&#xff0c;就变成了闭包&…

共享模型之管程(四)

1.wait/notify 1.1.为什么需要wait? 小故事: ①.假设多个用户(线程)都需要进入房间使用算盘(CPU)进行计算工作,但是为了保证计算过程中的安全,老王设计了一把锁(Synchronized),每次只允许一个用户(线程)拿到钥匙进入房间(成为Owner线程); ②.小南(线程)费了九牛二虎之力,抢…

【Docker】搭建Zookeeper集群

【Docker】搭建Zookeeper集群 下载镜像 docker pull zookeeper:3.5.8wy:study wy$ docker pull zookeeper:3.5.8 3.5.8: Pulling from library/zookeeperDigest: sha256:12af523731cbe390f5332d6c1e254f1d56c734a786910d5582653445a5cee299 Status: Downloaded newer image f…

Allegro174版本新功能介绍之动态铜皮对单独层面参数设置

Allegro174版本新功能介绍之动态铜皮对单独层面参数设置 Allegro升级到了174版本的时候,可以支持动态铜皮对单独的层面进行参数设置,如下图 具体操作如下 在低版本166以及172的时候,只有Global Dynamic Shape Parameter设置,如下图,只有全局的铜皮参数设置升级到了174时候…

WMS智能仓储管理系统源码 SpringMVC物流仓库管理系统源码

淘源码&#xff1a;国内知名的源码免费下载平台 需要源码学习可私信我。 系统介绍&#xff1a; 基于SpringMVCHibernatMinidao&#xff08;类Mybatis&#xff09;Easyui&#xff08;UI库&#xff09; Jquery Boostrap Ehcache Redis Ztree等基础架构开发的物流仓库管理系…

人脸识别:我是如何工作的?

任何自动人脸识别过程都必须考虑导致其复杂性的几个因素&#xff0c;因为人脸是一个动态实体&#xff0c;在多个因素的影响下不断变化&#xff0c;例如光照、姿势、年龄……这三个参数中的任何一个的变化都会导致同一个人的两幅图像之间的误差值大于不同个体的两幅图像之间的误…

分享136个PHP源码,总有一款适合您

PHP源码 分享136个PHP源码&#xff0c;总有一款适合您 136个PHP源码下载链接&#xff1a;https://pan.baidu.com/s/1A5sR357dh_SlS7pu33lW1Q?pwdkzgn 提取码&#xff1a;kzgn import os# 查找指定文件夹下所有相同名称的文件 def search_file(dirPath, fileName):dirs os…

红中私教-文件上传漏洞DVWA靶场实战(浅析)

前言 &#x1f340;作者简介&#xff1a;被吉师散养、喜欢前端、学过后端、练过CTF、玩过DOS、不喜欢java的不知名学生。 &#x1f341;个人主页&#xff1a;红中 首先呢&#xff0c;针对于文件上传漏洞 这个漏洞为什么存在&#xff1f;目的是什么&#xff1f;我们为什幺要攻击…

开发环境和测试环境共用Eureka

问题描述 在开发过程中会遇到一种情况&#xff0c;那就是只需要修改一个服务&#xff0c;但是这个服务依赖了其他的3个服务&#xff0c;导致开发人员在本地也要启动其他的3个服务&#xff0c;还要启动一个Eureka注册中心。问题显而易见&#xff0c;在依赖过多的情况下&#xf…

一种多维数据库的数据事务专利解读

什么是事务&#xff1f; 事务是数据库系统中的核心机制。我们要理解下事务概念&#xff1a;什么是事务呢&#xff1f;事务是并发控制的单位&#xff0c;是用户定义的一个操作序列。有四个特性(ACID)&#xff1a; 原子性(Atomicity)&#xff1a; 事务是数据库的逻辑工作单位&…

使用 VSCode 开发的必备插件,你都安装了吗?

0️⃣前言 VSCode是由微软研发的一款免费、开源的跨平台代码编辑器&#xff0c;目前是前端开发使用最多的一款软件开发工具。 因为每个开发者所接触项目、所有技术不同, 用到的插件不同, 但总有几个插件基本是必备的, 以下就给出一些插件推荐&#xff0c;希望能给大家一些参考。…

腾讯会议发布录屏工具“会记”,让云端视频协作随用随录、随享随看

随着云端协同成为新常态&#xff0c;企业和组织沟通的形式也在不断丰富。1月5日&#xff0c;腾讯会议发布云端录屏工具“会记”&#xff0c; 用户在腾讯会议中就能自由使用人像、屏幕、声音、窗口等多种组合方式进行录制&#xff0c;录制完成后视频将自动上传至云端&#xff0c…

Centos7.9安装WebLogic详细步骤

目录 一、weblogic下载 二、准备环境 三、创建用户和组 四、安装jdk 安装 五、安装WebLogic 1、使用root用户创建目录/opt/weblogic并授权 2.创建 oraInst.loc 文件 3、创建wls.rsp 响应文件 4、安装weblogic 5、静默创建域 六、启动weblogic 一、weblogic下载 直…

程序员面试中一面、二面、三面有什么区别?

很多公司面试都分一面、二面、三面甚至更多&#xff0c;大家可能会好奇&#xff0c;为什么要面这么多面&#xff0c;每一面又有啥区别呢&#xff1f; 首先我来回答下为什么要这么多面&#xff0c;最核心的是最后3点&#xff1a; 如果光是一个人面&#xff0c;担心会看走眼&…

解决IDEA中ctrl+shift+f快捷键搜索没反应的问题

文章目录0写在前面1 问题解决1.1 直接切换英文输入法1.2 win10 输入法1.3 搜狗输入法1.4 其他2 写在末尾0写在前面 今天想使用《在文件中查询》功能&#xff0c;使用ctrlshiftf进行搜索的时候&#xff0c;疯狂的按组合键一直没用。最后用手点的…… 原因是IDEA的快捷键与输入…

【 java 集合】List接口常用方法总结

&#x1f4cb; 个人简介 &#x1f496; 作者简介&#xff1a;大家好&#xff0c;我是阿牛&#xff0c;全栈领域优质创作者。&#x1f61c;&#x1f4dd; 个人主页&#xff1a;馆主阿牛&#x1f525;&#x1f389; 支持我&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4d…

五、条件构造器和常用接口

文章目录五、条件构造器和常用接口1、wapper介绍2、QueryWrapper2.1 例1&#xff1a;组装查询条件2.2 例2&#xff1a;组装排序条件2.3 例3&#xff1a;组装删除条件2.4 例4&#xff1a;条件的优先级2.5 例5&#xff1a;组装select子句2.6 例6&#xff1a;实现子查询3、UpdateW…

基于opencv的数字识别系统

一、目的 想要实现的功能&#xff1a;帮助我们在泵中扫描燃油&#xff0c;并在应用程序中输入燃油信息。 所需技术&#xff1a;①python程序对于拍摄的汽油泵的图像&#xff0c;尝试从中读取数字。——opencv实现。②先使用python对其进行原型设计&#xff0c;然后将代码转换…