如何将JS函数库发布到NPM

开发久了,你会发现在很多项目中,部分函数是通用的。大部分小伙伴的做法是从一个项目拷贝到另一个项目。有时会忘记某个函数是写在那个项目当中。此时,不如将平时常用的函数整理,发布一个自己的npm包。废话不多说:接下来,让我一步步搭建属于自己的npm包。

1、新建一个空白文件夹,执行如下命令

npm init -y

// 常用配置说明如下
npm 常用配置说明 name - 包名。
version - 包的版本号
scripts - 配置可被 npm 执行的命令
config - 设置配置属性,配合 scripts 属性使用
dependencies - 包依赖,会同该包一起安装
devDependencies - 包依赖,不会同该包一起安装
peerDependencies - 声明使用该插件时,宿主环境必需存在的插件
engines - 指定代码运行环境
os - 指定代码运行的操作系统
publishConfig - 发布时的配置
main - 其他项目引用该包时的入口文件
description - 包描述,可用于 npm 官网搜索
keywords - 包关键字,可用于 npm 官网搜索
homepage - 包的官网
urlbugs - 提交包 bug 的方式
license - 包许可证
author - 包作者,只能存在一个作者
contributors - 包的其他贡献者姓名

2、创建如下目录结构(后面说明具体作用)

// 后面具体说明每个文件的用处
.
├── README.md
├── babel.config.js
├── dist
│   └── lzytool.min.js
├── npm-publish.sh
├── package.json
├── src
│   ├── add.js
│   └── index.js
├── test
│   └── add.test.js
├── .mocharc.js
├── .npmignore
└── webpack.config.js

3、安装依赖包

// 用于babel配置
npm install @babel/cli @babel/core @babel/preset-env @babel/polyfill -D

// 用于单元测试
npm install @babel/register babel-plugin-transform-object-rest-spread chai mocha -D

// 用于webpack打包
npm install webpack webpack-cli babel-loader -D

4、配置bable

// 编辑 /babel.config.js 文件
// 传送门:https://www.babeljs.cn/docs
module.exports = {
    "presets": [
        ["@babel/preset-env", {
            "targets": {
                "ie": "8",
                "chrome": "58",
            },
        }]
    ],
    "plugins": [
        ["transform-object-rest-spread", { "useBuiltIns": true }]
    ]
}

5、配置 webpack

const path = require("path");
const TerserPlugin = require('terser-webpack-plugin');

module.exports = {
    // 设置mode为none避免默认压缩
    mode: 'none',
    // lzytool.min 为压缩文件,用于生产环境
    entry: {
        'lzytool': path.join(__dirname, "src/index.js"),
        'lzytool.min': path.join(__dirname, "src/index.js"),
    },
    // library相关文档
    // 传送门:https://www.webpackjs.com/configuration/output/#output-library
    output: {
        path: path.join(__dirname, "dist"),
        filename: '[name].js',
        library: 'webpackNumbers',
        libraryTarget: 'umd',
        globalObject: 'this',
    },

    // 配置 bable 模块,用于ES6以上语法转ES5
    // 传送门:https://webpack.js.org/loaders/babel-loader/#root
    module: {
        rules: [
            {
                test: /\.m?js$/,
                exclude: /(node_modules|bower_components)/,
                use: {
                    loader: 'babel-loader',
                    options: {
                        presets: ['@babel/preset-env']
                    }
                }
            }
        ]
    },
    // 创建 TerserPlugin 实例,覆盖默认的压缩配置。
    // 传送门:https://webpack.js.org/plugins/terser-webpack-plugin/
    optimization: {
        minimize: true,
        minimizer: [
            new TerserPlugin({
                include: /\.min\.js$/
            })
        ]
    }
}

6、编写一个的函数

//  编辑 /src/add.js
function add(x, y) {
    return x + y;
}
export default add;

// 编辑 /src/index.js 将 add 函数导出
export { default as add } from './add'

7、配置 package.json

// 主要配置 scripts
{
  "name": "zytool",
  "version": "1.0.0",
  "description": "整理常用的JS函数库",
  "main": "./dist/lzytool.min.js",
  "scripts": {
    "build": "webpack", // 用于打包
    "test": "mocha --require @babel/register" //用于单元测试
  },
  "author": "ZhouYi",
  "license": "MIT",
  "devDependencies": {
    "@babel/cli": "^7.8.4",
    "@babel/core": "^7.9.6",
    "@babel/polyfill": "^7.8.7",
    "@babel/preset-env": "^7.9.6",
    "@babel/register": "^7.9.0",
    "babel-loader": "^8.1.0",
    "babel-plugin-transform-object-rest-spread": "^6.26.0",
    "chai": "^4.2.0",
    "mocha": "^7.1.2",
    "terser-webpack-plugin": "^3.0.1",
    "webpack": "^4.43.0",
    "webpack-cli": "^3.3.11"
  },
}
// 执行打包命令
npm run build

// 得到如下结果
Hash: f10c45e2a9f76ae0b16f
Version: webpack 4.43.0
Time: 1100ms
Built at: 2020-05-13 16:35:02
         Asset      Size  Chunks             Chunk Names
lzytool.min.js  1.29 KiB       0  [emitted]  lzytool.min
Entrypoint lzytool.min = lzytool.min.js
[0] ./src/index.js 39 bytes {0} [built]
[1] ./src/add.js 59 bytes {0} [built]

8、配置 .mocharc.js

// 用于单元测试
module.exports = {
    diff: true,
    extension: ['js'],
    package: './package.json',
    reporter: 'spec',
};

9、配置 .npmignore

// 用于npm发包

.DS_Store
.mocharc.js
node_modules
npm-debug.log*
yarn-debug.log*
yarn-error.log*
babel.config.js
webpack.config.js
npm-publish.sh

# Editor directories and files
.idea
.vscode
*.suo
*.ntvs*
*.njsproj
*.sln

10、单元测试

// 编辑 /test/add.text.js

import chai from 'chai';
import { add } from '../dist/lzytool.min';

let expect = chai.expect;

describe('加法函数的测试', function () {
    it('1 加 1 应该等于 2', function () {
        expect(add(1, 1)).to.be.equal(2);
    });
});

// 执行 npm run test
// 得到如下结果

加法函数的测试
    ✓ 1 加 1 应该等于 2

  1 passing (3ms)

11、注册NPM账号

传送门 https://www.npmjs.com/

12、登录 npm 、发布包

 npm login
// 输入你刚注册的用户名和密码

npm publish 
// 发包

以上只是发布一个简单的JS函数包到NPM的过程。
相关配置说明可以通过传送门查看文档哈。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352