开发并发布依赖包,作为工具包供别人npm install
1.初识包及 npm
包的概念:
nodejs 中的第三方模块叫包
不同于 nodejs 中的内置模块与自定义模块,包是由第三方个人或团队开发出来的,免费供所有人使用
nodejs 中的包都是免费开源的,不需要付费即可免费下载使用
为什么需要包
由于 nodejs 的内置模块仅仅提供了一些底层的 API,导致在基于内置模块进行项目开发的时候,效率很低
包是基于内置模块封装出来的,提供了更高级,更方便的 API,极大的提高开发效率
包和内置模块之间的关系,类似于 jQuery 和浏览器内置 API 之间的关系
包从哪里下载
npm,Lnc.公司旗下的著名网站
https://www.npmjs.com/ 这个网站搜索需要的包
全球最大的包共享平台,你可以从这个网站上搜索到任何你需要的包
npm,Lnc.公司提供一个服务器地址,共享所有的包
https://registry.npmjs.org/ 这个服务器地址可以下载需要的包
如何下包
npm,Lnc.公司提供一个包管理工具
下载 xxx 包
npm install xxx
2.解决下包速度慢的问题
npm 设置镜像源
查看当前下包镜像源
npm config get registry
将下包镜像源切换到淘宝镜像源
npm config set registry=https://registry.npm.taobao.org/
查看
nrm 切换 npm 下包镜像源
nrm 安装
将 nrm 安装为全局可用的工具
npm i nrm -g
查看所有 npm 镜像源
nrm ls
将镜像源切换到 taobao 镜像
nrm use taobao
3.自定义 npm 包,以及包的发布
自定义 npm 包
自定义 npm 包目录结构
|---src
|------dateFormat.js
|------escapeHTML.js
|---index.js
|---package.json
|---readme.md
package.json
{
"name": "gyc_tools",
"version": "1.0.0",
"main": "index.js",
"description": "格式化时间,HTMLEscape功能",
"keywords": ["gyc", "dateForm", "escape"],
"license": "ISC"
}
"name": "gyc_tools", // 包的名字
"version": "1.0.0", // 包的版本
"main": "index.js", // 包的入口文件
"description": "格式化时间,HTMLEscape 功能", // 包的功能描述
"keywords":["gyc","dateForm","escape"], // 包的关键字
"license": "ISC" // 包的开源协议
index.js
const date = require('./src/dateFormat')
const escape = require('./src/escapeHTML')
module.exports = {
...date,
...escape,
}
README.md
## 安装
npm i gyc-tools
## 导入
const gyc = require('gyc-tools')
## 格式化时间
// 调用 dateFormat 对时间进行格式化
const dtstr = gyc.dateFormat(new Date())
// 结果 2022-02-00 16:18:51
console.log(dtstr)
## 转义 HTML 中的特殊字符
// 调用 htmlEscape 方法进行转换
const str = gyc.htmlEscape(hrmlStr)
// 结果<h1 title="abc">这是 h1 标签<span>这是 span 标签 123 &nbsp;</span></h1>
console.log(str)
## 还原 HTML 中的特殊字符
// 调用 htmlUnEscape 方法进行还原
const str2 = gyc.htmlUnEscape(hrmlStr)
// 结果<h1 title="abc">这是 h1 标签<span>这是 span 标签 123 </span></h1>
console.log(str2)
## 开源协议
ISC
开发并发布依赖包,作为工具包供别人npm install的更多相关文章
- [实践]使用JarJar优雅的发布依赖包
[实践]使用JarJar优雅的发布依赖包 打包工具: Jar Jar Links是一个Java类库重新打包工具. 可以帮助你将其它用到的java库打包并嵌入到你自己的项目jar包中.这样做的原因有: ...
- Cloudera5.8.3 HBase1.2.0开发必须的jar包
Cloudera的HBase开发环境下载依赖包特别麻烦,通常是直接在CDH服务器上拷.
- ubuntu安装greenplum依赖包
ubuntu安装greenplum的过程中有两个比较难找的包,特地写出来给大家分享一下: 错误提示1:configure: error: header file <ldap.h> is r ...
- Maven - 实例-2-使用本地仓库中的依赖包
Maven引入构建包的流程 执行mvn compile命令编译源代码,如果编译过程中需要用到其他的包, maven将会在pom.xml文件中查找是否引入该依赖包的坐标. 示例: <depende ...
- CentOS6.5 安装Python 的依赖包
1.CentOS6.5 安装Python 的依赖包 yum groupinstall "Development tools"yum install zlib-devel bzip2 ...
- Yum 下载安装包及对应依赖包
Yum 下载安装包及对应依赖包: 安装该软件:yum install -y yum-plugin-downloadonly 以下载 openssh-server 为例 yum install -y o ...
- 开发并发布npm包,支持TypeScript提示,rollup构建打包
前言: 工作了几年,想把一些不好找现成的库的常用方法整理一下,发布成npm包,方便使用.也学习一下开发发布流程. 主要用到的工具:npm. 开发库:babel.typescript.rollup.es ...
- Spring MVC 学习笔记12 —— SpringMVC+Hibernate开发(1)依赖包搭建
Spring MVC 学习笔记12 -- SpringMVC+Hibernate开发(1)依赖包搭建 用Hibernate帮助建立SpringMVC与数据库之间的联系,通过配置DAO层,Service ...
- npm包开发与发布
把通用的功能开发成npm包,便用使用和维护,更重要的是可以分享给广大的开发者,是不是很激动人心! 那么,步骤如下: 1.创建项目 创建项目目录,npm init ,根据需要输入配置信息(建完后也可以在 ...
随机推荐
- 来自开发者的点赞!HMS Core荣获多个行业奖项
2021年,HMS Core发布全新HMS Core 6,为全球开发者提供多终端.跨OS.全场景的华为移动服务核心能力,和开发者共同成长.通过和开发者在行业解决方案.业务场景创新和商业增长上的持续合作 ...
- Java多线程专题4: 锁的实现基础 AQS
合集目录 Java多线程专题4: 锁的实现基础 AQS 对 AQS(AbstractQueuedSynchronizer)的理解 Provides a framework for implementi ...
- Homework_1
寒假第一份作业 一.博客园部分 1.个人博客园链接 Click here 2.markdown界面截图 我用typora编辑 所以贴上typora界面的截图 二.Github部分 1.个人Github ...
- SIFT Learing records
目录 SIFT算法的步骤 小结 附录代码 花了一周的时间去读了一下SIFT的原论文,相关的一些视频还有文章,大体了解了其思想和步骤,在这里记录一下吧. SIFT是一种提取图像中具有尺度不变性的关键点的 ...
- web.xml 配置文件?
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http:// ...
- 不使用pvc的方式在K8S中部署apisix-gateway
不使用pvc的方式在K8S中部署apisix-gateway 简介 我的apisix使用etcd作为数据存储服务器,官方的使用pvc方式或者docker-compose的方式,对于新手不太友好,本篇是 ...
- AT2043 [AGC004C] AND Grid
首先可以发现一个很简单的想法,因为最外层是一定不会有 \(\#\) 的,所以可以考虑让第一个网格图将每个连通块的最外层包起来,第二个网格图将就选择这个包内部的所有点即可. 但你发现这个想法是很难实现的 ...
- Spring中NESTED和REQUIRED_NEW传播行为的区别
简介 PROPAGATION_REQUIRED_NEW: 表示当前方法必须运行在它自己的事务中.一个新的事务将被启动.如果存在当前事务,在该方法执行期间,当前事务会被挂起.如果使用JTATransac ...
- js中全局和局部变量的区别
2 3 4 5 6 7 8 9 10 <script type="text/javascript"> var a = 1; function hehe() { ...
- Docker的数据管理、网络通信和dockerfile
Docker的数据管理.网络通信和dockerfile 目录 Docker的数据管理.网络通信和dockerfile 一.Docker的数据管理 1. 数据卷 1.1 数据卷定义 1.2 数据卷配置 ...