前言:

工作了几年,想把一些不好找现成的库的常用方法整理一下,发布成npm包,方便使用。也学习一下开发发布流程。

主要用到的工具:npm。

开发库:babel、typescript、rollup、eslint、corejs。

由于目前只是发布一些函数方法,只需要一些兼容性工具,打包工具即可。

一、创建项目

可以直接在github上创建一个空项目,然后克隆到本地。

进入目录下,执行

  1. npm initz

之后将开始初始化package.json:

  1. This utility will walk you through creating a package.json file.
  2. It only covers the most common items, and tries to guess sensible defaults.
  3.  
  4. See `npm help init` for definitive documentation on these fields
  5. and exactly what they do.
  6.  
  7. Use `npm install <pkg>` afterwards to install a package and
  8. save it as a dependency in the package.json file.
  9.  
  10. Press ^C at any time to quit.
  11. package name: (cs) csdrv
  12. version: (1.0.0) 0.0.1
  13. description: 描述内容
  14. entry point: (index.js)
  15. test command: 测试命令
  16. git repository: git远程仓库
  17. keywords: 描述这个包的关键词
  18. author: axelccc
  19. license: (ISC)
  20. About to write to D:\LiFile\code\cs\package.json:
  21.  
  22. {
  23. "name": "csdrv",
  24. "version": "0.0.1",
  25. "description": "描述内容",
  26. "main": "index.js",
  27. "scripts": {
  28. "test": "测试命令"
  29. },
  30. "repository": {
  31. "type": "git",
  32. "url": "git远程仓库"
  33. },
  34. "keywords": [
  35. "描述这个包的关键词"
  36. ],
  37. "author": "axelccc",
  38. "license": "ISC"
  39. }
  40.  
  41. Is this OK? (yes) y

此时有了一个空项目。

二、编辑方法

新建src目录,用于存放源代码。新建dist目录,用于存放打包后的文件。新建test目录,用于某些测试方法。目录名称无要求。

新建函数文件hideStr.js,本例创建一个 脱敏字符的方法:

  1. /**
  2. * 脱敏字符返回
  3. * 小数点前全脱敏,如果没有小数点,最多脱敏两位 脱敏与真实位数对应
  4. * value 数值 hideLength 脱敏位数
  5. */
  6.  
  7. export function hideStr({ value = 0, hideLength = 2, replaceChar = "*" }) {
  8. let hideStr = "";
  9.  
  10. if (typeof value != "number" && typeof value != "string") {
  11. console.warn("需要输入数字或者字符串,否则结果将会异常");
  12. }
  13.  
  14. try {
  15. const str = String(value);
  16. const [integer, decimal] = str.split(".");
  17. for (let i = integer.length - 1; i >= 0; i--) {
  18. // 前 hidelength 位 换成 *
  19. if (integer.length - i > hideLength) {
  20. hideStr += integer[i];
  21. } else {
  22. hideStr += replaceChar;
  23. }
  24.  
  25. // 前 除了最后一位 每3位加一个 ,
  26. if (i % 3 == 0 && i != 0) {
  27. hideStr += ",";
  28. }
  29. }
  30.  
  31. decimal && (hideStr += `.${decimal}`);
  32. } catch (error) {
  33. console.log(`脱敏异常`, error);
  34. }
  35.  
  36. return hideStr;
  37. }

新建src/index.js,作为入口文件,引入上文的方法,并导出。此处index.js主要是起到归集作用。

  1. import { hideStr } from "./hideStr";
  2. import { separator } from "./separator";
  3. import { unitByBit, unitByByte, unitToChinese } from "./unitFormat";
  4.  
  5. export { hideStr, separator, unitByBit, unitByByte, unitToChinese };

理论上,这个时候发布,是可以引入使用了,但是此时过于粗糙,存在测试做不了,不支持ts,没有构建编译后的文件等问题。

三、引入ts支持

如果不需要ts支持,可以跳过本步骤。该步骤主要是编辑ts描述文件,以增加ts提示信息等。

与index.js同级增加index.d.ts文件。

  1. declare module "csdrv";
  2. export { hideStr } from "./hideStr";
  3. export { unitByByte, unitByBit, unitToChinese } from "./unitFormat";
  4. export { separator } from "./separator";
  5. export type { hideStrIn, sepIn, unitRes } from "./interface";

hideStr.d.ts

  1. import { hideStrIn } from "./interface";
  2. /**
  3. * @return 脱敏后的字符串
  4. */
  5. declare function hideStr({ value, hideLength, replaceChar }: hideStrIn): string;
  6.  
  7. export { hideStr };

interface.d.ts 定义的一些接口规范

  1. /**
  2. * cn:对数字前几位脱敏
  3. */
  4. interface hideStrIn {
  5. // 被脱敏的数字
  6. value: number | string;
  7. // 保留字符的长度
  8. hideLength?: number;
  9. // 脱敏的代替字符
  10. replaceChar?: string;
  11. }
  12.  
  13. /**
  14. * cn:将数字进行 多位分隔,默认三位
  15. */
  16. interface sepIn {
  17. // 被处理的数字
  18. num: number;
  19. // 几位一分割
  20. n?: number;
  21. }
  22.  
  23. /**
  24. * cn:单位格式化 后返回的结构
  25. * en:result after format
  26. */
  27. interface unitRes {
  28. value: number; // 要被格式化的数字
  29. // 格式化之后的单位
  30. unit: string;
  31. }
  32.  
  33. export { hideStrIn, sepIn, unitRes };

四、生成打包编译后文件

生成编译后的文件,可以方便引用。尝试rollup工具打包。

rollup和webpack类似,都是一类打包工具。为了兼容性,引入babel处理。注:需要的包不要忘记npm,也不要忘记添加corejs。

.babelrc文件简单配置:

  1. {
  2. "presets": [
  3. [
  4. "@babel/preset-env",
  5. {
  6. "modules": false,
  7. "useBuiltIns": "usage",
  8. "corejs": "2"
  9. }
  10. ]
  11. ],
  12. "plugins": [["@babel/plugin-transform-runtime"]],
  13. "ignore": ["node_modules/**"]
  14. }

根目录下创建rollup.config.js:

  1. import resolve from "rollup-plugin-node-resolve"; // 依赖引用插件
  2. import commonjs from "rollup-plugin-commonjs"; // commonjs模块转换插件
  3. import babel from "rollup-plugin-babel"; // babel 插件
  4. import { eslint } from "rollup-plugin-eslint"; // eslint插件
  5.  
  6. export default {
  7. input: "./src/index.js", // 打包的入口文件
  8. output: {
  9. name: "csdrv", // 输入的包名
  10. file: "./dist/csdrv.js", // 打包输出地址, 这里的导出地址就是package内main的地址
  11. format: "umd", // 包类型
  12. },
  13. plugins: [
  14. // 使用的插件
  15. resolve(),
  16. commonjs(),
  17. babel({
  18. exclude: "node_modules/**",
  19. runtimeHelpers: true,
  20. }),
  21. eslint({
  22. throwOnError: true,
  23. include: ["src/**"],
  24. exclude: ["node_modules/**"],
  25. }),
  26. ],
  27. ignore: [
  28. "node_modules/**", // 忽略目录
  29. ],
  30. };

package.json增加 build脚本命名:

  1. "scripts": {
  2. "build": "rollup -c rollup.config.js",
  3. },

执行 npm run build,即可生成构建后的csdrv.js。中间因为缺失依赖报错,请安装依赖。

五、完善readme.md,package.json信息

自述文件得写一下。

package.json可以额外追加一些参数:参考http://nodejs.cn/learn/the-package-json-guide。

或者找到一些开源项目参考一下。

六、本地测试

1.可以在test目录下创建测试脚本,正常引入即可。

2.使用npm link方式,在其它工程中引入。

七、发布

测试,引入没啥问题了,就大胆发布吧。

首先登录npm。

npm login

输入账号,邮箱,密码。

npm publish 即可发布。注:每次发布版本号不可一致,确认好再发。

最后:https://www.npmjs.com/package/csdrv ,万一以后能干掉lodash呢(大雾hh)。

开发并发布npm包,支持TypeScript提示,rollup构建打包的更多相关文章

  1. 创建并发布npm包

    1.npm官网创建npm账户 npm网站地址:https://www.npmjs.com/ npm网站注册地址:https://www.npmjs.com/signup 2.命令行工具登录npm np ...

  2. 使用cnpm搭建私有NPM仓库 发布npm包

    关于如何使用cnpm搭建私有的npm仓库看这里→ http://blog.fens.me/nodejs-cnpm-npm/ 我本人还没有机会真正实践操作过,公司的npm仓库是我老大搭建的,我这里仅仅记 ...

  3. 不会发布npm包?进来看看?

    前言 npm(Node Package Manager),一个Node的包管理器,平时我们常用的公共模块(插件)或者叫做包大多都放在上面,所以接下来要封装的插件,我们就简单称它为npm包,本文从就从这 ...

  4. 使用Vue-cli3.0创建的项目,如何发布npm包

    使用Vue-cli3.0创建的项目,如何发布npm包 在使用vue进行项目开发时,如果我们想要发布一个包,有时候会有点迷糊,不知道应该怎么修改脚手架的默认设置.这里记录一下一些常见的操作. 创建ind ...

  5. 前端组件用 Scope 发布 npm 包的方法

    1.引言 多人.多组织或多组件发布 npm 包到同一个仓库时,可能出现命名冲突问题. 为了解决这个问题,npm 引入了“scope”(范围)概念. 在 Angular 项目中,我们通常可以看到“@an ...

  6. 发布nuget包的正确姿势---cicd自动打包发布nuget包

    最轻便的发布nuget包方式,方便cicd自动打包发布nuget包 首先新建项目 项目名随便取,这里就叫它GuiH.ClassLibrary 默认即可,需要改目标版本时,等创建好再改 项目创建好了 随 ...

  7. 开发并发布依赖包,作为工具包供别人npm install

    1.初识包及 npm 包的概念: nodejs 中的第三方模块叫包 不同于 nodejs 中的内置模块与自定义模块,包是由第三方个人或团队开发出来的,免费供所有人使用 nodejs 中的包都是免费开源 ...

  8. 使用vuecli3发布npm包

    一.使用vuecli3创建项目 vue create svgicon 二.修改目录,开发组件前的准备 把src目录改为examples作为查看组件的演示目录,新建packages目录作为组件编写的目录 ...

  9. 用@vue/cli发布npm包

    1.环境准备 安装node,npm,@vue/cli 2.初始化项目 用@vue/cli创建新项目 vue create mtest-ui 删除public,main.js,App.vue等无关文件, ...

随机推荐

  1. ZooKeeper 面试题?

    ZooKeeper 是一个开放源码的分布式协调服务,它是集群的管理者,监视着集群 中各个节点的状态根据节点提交的反馈进行下一步合理操作.最终,将简单易用 的接口和性能高效.功能稳定的系统提供给用户. ...

  2. String是最基本的数据类型吗?

    基本数据类型包括byte.int.char.long.float.double.boolean和short.java.lang.String类是final类型的,因此不可以继承这个类.不能修改这个类. ...

  3. 您对 Distributed Transaction 有何了解?

    分布式事务是指单个事件导致两个或多个不能以原子方式提交的单独数据源的突 变的任何情况.在微服务的世界中,它变得更加复杂,因为每个服务都是一个工 作单元,并且大多数时候多个服务必须协同工作才能使业务成功 ...

  4. 如何设置出IDEA中VCS下的Enable Version Control Intergration

    File–>settings–>Version Control

  5. 利用Properties类关联相关配置文件

    文件目录 代码: package Lianxi;import java.io.FileInputStream;import java.io.FileNotFoundException;import j ...

  6. python学习笔记(九)——线程与进程

    一.线程 Python 中为我们提供了两个模块来创建线程. _thread threading thread 模块已被废弃.用户可以使用 threading 模块代替.所以,在 Python 中不能再 ...

  7. 深入解析丨母婴App如何迅速收割2W新用户?

    在讲案例前,我们需要先说一下精细化分析. 我们常说的精细化分析,就是一个持续"解构"的过程,通过像漏斗.留存.细分等高级分析功能,将"整体"按照事件属性解构成& ...

  8. BootstrapBlazor实战-Tree树形控件使用(1)

    实战BootstrapBlazor树型控件Tree的使用, 以及整合Freesql orm快速制作数据库后台维护页面 demo演示的是Sqlite驱动,FreeSql支持多种数据库,MySql/Sql ...

  9. vs技巧 - 调试asp.net core源码

    学习asp.net core的方式除了看官方文档,看源码是也是一种很好的方式.本文介绍一种方法,简单配置vs,无需第三方插件就可以将asp.net core的源码链接自己的项目,随时穿梭于core的源 ...

  10. 时间盲注——AS别名让盲注不盲

    用处 页面存在时间盲注,注入成功了,你啥也看不到. 这只是为了能够查看到注入后的结果 网站部分源代码 <?php $conn = mysqli_("127.0.0.1",&q ...