【译】发布你自己的npm包

作者 : 开心源码 本文共1910个字,预计阅读时间需要5分钟 发布时间: 2022-05-12 共182人阅读

banner

备注:npm板块有个神奇的样板。这篇文章是基于我从设置中学到的东西。

如今,NPM已经成为javascript库的事实上的注册表。特别是React,Angular和其余前台库主导的网络和node.js接管的服务器端,NPM软件包比以往任何时候都更受欢迎。通常,我们会在代码中引入实用包,比方typy,sugar,并轻松的使用它们。

那么,你有没有想过编写自己的实用程序/库,并将其发布到NPM上面,以便在世界任何的地方可以重复使用它?假如是,那就继续阅读。?

我们将在本文中详情以下部分。

  1. 为什么?
  2. 发布的步骤
  3. 样板文件

为什么?

当你在多个项目中工作时,你经常发现自己在多个项目中重复简单的事情。举个例子,以你想要的方式解析日期并对其进行格式化。大多数开发者只是从一个项目复制代码到另一个项目中使用它,由于它只是几行代码。但更好的方法是提取代码并将其放在一个公共的位置,以便你可以从任何项目中访问它。NPM是一个理想且不断发展的生态系统,并且可以免费使用它。所以,从长远看,将所有可重用代码作为npm包发布上去将会帮助到你。

无论代码有多少,无论是一行还是一千行,都可以将其作为包发布,以便在多个代码库中轻松使用。

此外,你还可以成为这个库的作者。多么酷啊!??

发布的步骤

发布通常是一个简单的过程。

code => test => publish => revise code => test => publish new version ...

入口

创立一个新目录(,进入目录)并从终端输入以下命令。

npm init

(根据提醒)输入有意义的包名称和包的相应详细信息。这将为你创立package.json。所有NPM包都需要main键。这定义了我们库的入口点。默认情况下,这入口点将是index.js,但是你可以根据你自己的情况来更改入口点(文件)。

对于Babel或者基于bundle的库,入口点通常位于构建目录中。

源码

假如你正在编写一个小型库,则可以将所有代码放入index.js中。但是,更常见的是,我们将笼统代码并将其放入单独的文件中。所以,理想的方法是将所有源代码保存在src中。

这是目前最广泛使用和推荐的源代码设置,虽然它从一个库到另一个库中有所不同。

  • ES6 — Babel
  • Linting — ESLint
  • Code formatting — Beautify/Prettier
  • Bundling — Webpack

我们大多数的人已经知道(上面)这些事,所以,我仅仅列出来,把它们留给你弄清楚。

测试

你需要进行全面测试,以确保你的代码按照预期工作。有各种测试设置。你可以使用最适合你需求的。那么,广泛使用的测试设置有

  • JavaScript Utility?—?Mocha
  • React Library?—?Jest with Enzyme
  • Angular Library?—?Karma with Jasmine

… 等等

假如你需要代码覆盖率,我很喜欢(覆盖率),Istanbul是任何JavaScript项目的最佳覆盖工具之一。我非常喜欢它。

发布

一旦你的代码通过了测试,那么可以准备发布了。

  1. 在npmjs.com中创立一个账号。
  2. 在控制台上运行下面的指令
npm login

输入你的客户名和密码。这将存储凭据,因而你不必为每次发布输入凭据。

  1. 现在去发布,运行(下面指令)
npm publish

这会将你的包发布到NPM注册表。发布完成后(不到一分钟),你可以在链接https://www.npmjs.com/~{username}/{package-name}中查看你的包。

假如你想对包进行更改,则必需更改版本号并再次发布。

请记住使用npm命令npm version patchnpm version minornpm verson major来自动升级版本,而不是手动升级它们。这些命令是基于语义版本控制。

样板文件

我有少量我自己的npm软件包,并在线研究了创立NPM软件包的所有最佳实践,并专门为此创立了样板文件。它具备预先设置的所有功能,以便你可以在几秒钟内开始使用。假如你正在寻觅编写JavaScript util包,它可能只是你的样板。

样板文件的链接 — npm-module-boilerplate。

你是最棒的!祝你渡过美好的一天!??

后话

原文:https://hackernoon.com/publish-your-own-npm-package-946b19df577e

文章首发: reng99/blogs/issues/25

同步掘金:https://juejin.im/post/5ce4ce0f51882572e42300bd

更多内容: reng99/blogs (客官可否star下仓库啊@~@!)

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 【译】发布你自己的npm包

发表回复