前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >推荐一波实用高效的 NPM 工具包,总有几款适合你

推荐一波实用高效的 NPM 工具包,总有几款适合你

作者头像
前端达人
发布2021-09-08 09:58:42
3.9K0
发布2021-09-08 09:58:42
举报
文章被收录于专栏:前端达人前端达人
面对繁忙的日程安排与紧迫的工期限制,选择能够切实提升生产率的工具无疑至关重要。

在这里,我整理出一份个人最喜欢的 NPM 软件包清单。为了便于浏览,我还对它们进行了分类,希望呈现出更加清晰的结构。

当然,大家不必全数安装与学习。在大多数情况下,每个类别选择一款就足以解决生产需求。我只是想多提供一点替代方案,帮助每位读者朋友找到最适合自己的选项。闲言少叙,咱们马上开始!

🧰 实用工具

Lodash

lodash[1]是一套现代 JavaScript 实用程序库,提供模块化、性能与多种附加功能。可提供关于 JavaScript 数组、对象及其他数据结构的多种实用功能。

lodash-logo

安装及示例
代码语言:javascript
复制
yarn add lodash

不要滥用,尽量使用 ES 自带方法 。我常用的一些方法如下

代码语言:javascript
复制
// -----------------------------深度比较两个对象的值是否全相等
import { isEqual, cloneDeep, uniqBy, sortBy } from "lodash";

const object = { a: 1 };
const other = { a: 1 };

isEqual(object, other);
// => true

object === other;
// => false

// -----------------------------深拷贝
const objects = [{ a: 1 }, { b: 2 }];

const deep = cloneDeep(objects);
console.log(deep[0] === objects[0]);
// => false

// -----------------------------数组去重
uniqBy([{ x: 1 }, { x: 2 }, { x: 1 }], "x");
// => [{ 'x': 1 }, { 'x': 2 }]

// -----------------------------数组排序
const users = [
  { user: "fred", age: 48 },
  { user: "barney", age: 36 },
  { user: "fred", age: 40 },
  { user: "barney", age: 34 },
];
sortBy(users, "age");
/*
[
  { 'user': 'barney', 'age': 34 },
  { 'user': 'barney', 'age': 36 },
  { 'user': 'fred', 'age': 40 },
  { 'user': 'fred', 'age': 48 },
];
*/

qs

`qs`[2] 处理 URL 查询字符串,支持内嵌对象和数组。简而言之,就是将对象和 URL 地址的参数互相转换

qs-github

安装及示例
代码语言:javascript
复制
yarn add qs
代码语言:javascript
复制
import { parse, stringify } from "qs";

// 用途一
// 将 浏览器上 URL地址参数转换为对象(字符串转对象)
const urlParams = parse(window.location.href.split("?")[1]);

// 用途二
// 将对象参数 传递给到后端接口--GET 请求  (对象转字符串)
const params = {
  name: "wang",
  age: "18",
  sex: "女",
};

// =>  /api/user?name=wang&age=18&sex=%E5%A5%B3
const apiUrl = `/api/user?${stringify(params)}`;

classnames

classnames[3]有条件地将类名组合在一起

安装及示例
代码语言:javascript
复制
yarn add classnames

错误 ❎ 代码示例: React 原生动态添加多个样式类名会报错:

代码语言:javascript
复制
import styles from "./index.less";

const Index=()=><div className={styles.class1 styles.class2}</div>

修改为如下代码即可解决

代码语言:javascript
复制
import React from "react"
import classnames from 'classnames'

import styles from "./index.less";

const Index=()=>(<div
          className=classnames({
              styles.class1,
              styles.class2
          })>
</div>)

numeral

numeral[4]是一个专门用来格式化数字的 NPM 库,同时 numeral 还能解析各种格式的数字。

numeral-github

安装及示例
代码语言:javascript
复制
yarn add numeral
代码语言:javascript
复制
import numeral from "numeral";

// 解析数字
numeral("10,000.12"); // 10000.12
numeral("$10,000.00"); // 10000
numeral("3.467TB"); // 3467000000000
numeral("-76%"); // -0.76

// 格式化

numeral(10000.23).format("0,0"); // '10,000'
numeral(1000.234).format("$0,0.00"); // '$1,000.23'

cross-env

cross-env[5]是一个运行跨平台设置和使用环境变量的脚本

安装及示例
代码语言:javascript
复制
yarn add cross-env --dev
代码语言:javascript
复制
  "scripts": {
    "start": "cross-env REACT_APP_ENV=development webpack",
    "build": "cross-env REACT_APP_ENV=production webpack",
  },

path-to-regexp

path-to-regexp[6]用来处理 url 中地址与参数,能够很方便得到我们想要的数据。

js 中有 RegExp 方法做正则表达式校验,而 path-to-regexp 可以看成是 url 字符串的正则表达式。

安装及示例
代码语言:javascript
复制
yarn add path-to-regexp

pathToRegexp方法可以类比于 js 中 new RegExp('xxx')

代码语言:javascript
复制
import pathToRegexp from "path-to-regexp";

const re = pathToRegexp("/foo/:bar");
console.log(re); // /^\/foo\/((?:[^\/]+?))(?:\/(?=$))?$/i

compile用于填充 url 字符串的参数值。

代码语言:javascript
复制
var pathToRegexp = require("path-to-regexp");

var url = "/user/:id/:name";
var data = { id: 10001, name: "bob" };

// /user/10001/bob
console.log(pathToRegexp.compile(url)(data));

📅 日期格式

Day.js

Day.js[7] 是一款快速且轻量化的 Moment.js[8](自 2020 年 9 月起进入纯维护模式,不再开发新版本) 替代方案。二者拥有类似的 API,只要你接触过 Moment.js,就能够快速上手 Day.js

dayJS-office

安装
代码语言:javascript
复制
yarn add dayjs
示例
代码语言:javascript
复制
import dayjs from "dayjs";

const myformat = "YYYY-MM-DD HH:mm:ss";

// -------------------------以字符串形式返回 当前时间
const data = dayjs().format(myformat);
// =>  2020-11-25 12:25:56

// -------------------------日期格式化
const data1 = dayjs("2020-11-25 12:25:56").format("YYYY/MM/DD HH/mm/ss");
// => 2020/11/25 12/25/56

// -------------------------多久之前
var relativeTime = require("dayjs/plugin/relativeTime");
dayjs.extend(relativeTime);
const data1 = dayjs("2020-11-25 11:40:41").fromNow();

// =>

🌷 Linters 与格式化工具

ESLint

ESLint[9] 是一个很好用的工具,可用来避免代码错误并强制开发团队使用编码标准。ESLint 是用于识别和报告 ECMAScript/JavaScript 代码中模式的工具。ESLint 具备全面的可插入特性,每项规则对应一款插件,供你在运行时添加更多内容。

eslint-offcial

安装和使用
代码语言:javascript
复制
$ yarn add eslint --dev

然后,你应该设置一个配置文件:

代码语言:javascript
复制
$ ./node_modules/.bin/eslint --init

之后,你可以在任何文件或目录上运行 ESLint,如下所示:

代码语言:javascript
复制
$ ./node_modules/.bin/eslint yourfile.js

有关更多说明,请参阅官方文档[10],其中有许多入门和配置示例。

Prettier

Prettier[11] 是一款风格鲜明的代码格式化程序。它通过解析代码并使用自己的规则(限定最大行长)对代码进行重新输出,借此实现统一的样式;

prettier-office

安装
代码语言:javascript
复制
yarn add --dev --exact prettier
示例

创建 .prettierrc.js 加入自定义格式化规则

代码语言:javascript
复制
module.exports = {
  trailingComma: "es5",
  tabWidth: 4,
  semi: false,
  singleQuote: true,
};

创建 .prettierignore 加入需要忽略的文件或目录

代码语言:javascript
复制
# Ignore artifacts:
build
coverage

执行格式化命令

代码语言:javascript
复制
# 格式化src目录下的所有js文件

prettier --write "src/**/*.js"

stylelint

stylelint[12] 一个强大的样式规则,可以让你强制执行样式规范,避免书写错误的样式代码

安装
代码语言:javascript
复制
yarn add stylelint stylelint-config-standard --dev
示例

创建.stylelintrc.js并加入配置

代码语言:javascript
复制
module.exports = {
  extends: "stylelint-config-standard",
};

执行 lint 命令

代码语言:javascript
复制
# 检查 src目录下所有css文件是否符合规范
npx stylelint "src/**/*.css"

Husky

Husky[13] 可以帮助我们简单直接地实现 git hooks。你们团队正在协作开发,并希望在整个团队中推行一套编码标准?没问题!有了 Husky,你就可以要求所有人在提交或推送到存储库之前自动完成 lint 并测试其代码。

HUSKY-GITHUB

安装及示例
代码语言:javascript
复制
yarn add husky --dev

下面是一个实现 husky hooks 的示例:

代码语言:javascript
复制
// package.json
{
  "husky": {
    "hooks": {
      "pre-commit": "npm lint",
      "pre-push": "npm test"
    }
  }
}

这里 pre-commithooks 会在你提交到存储库之前运行。在将代码推送到存储库之前,将运行 pre-push hook


🧙‍♂️ 数据生成器

Uuid

uuid[14]是一个便捷的微型软件包,能够快速生成更为复杂的通用唯一标识符(UUID)。

安装及示例
代码语言:javascript
复制
npm install uuid
代码语言:javascript
复制
import { v4 as uuidv4 } from "uuid";
uuidv4(); // ⇨ '9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d'

faker.js

faker.js[15]非常实用的工具包,用于在浏览器及 Node.js 中生成大量假数据。

faker-github

安装及示例
代码语言:javascript
复制
yarn add faker
代码语言:javascript
复制
import faker from "faker"

function generateCustomers () {
  const customers = []

  for (let id = 0; id < 50; id++) {
    const firstName = faker.name.firstName()
    const lastName = faker.name.firstName()
    const phoneNumber = faker.phone.phoneNumberFormat()
    const zipCode = faker.address.zipCode()
    const date = faker.date.recent()

    customers.push({
      id,
      firstName,
      lastName ,
      phoneNumber ,
      zipCode,
      date
    })
  }

  return { customers }

Mock.js

Mock.js[16] 是一个模拟数据生成器,可帮助前端开发和原型与后端进度分开,并减少某些单调性,尤其是在编写自动化测试时。

moackjs-github

安装及示例
代码语言:javascript
复制
npm install mockjs
代码语言:javascript
复制
import Mock from "mockjs";

const Random = Mock.Random

function generateCustomers () {
  const customers = []

  for (let id = 0; id < 50; id++) {
    const firstName = Random.first()
    const lastName = Random.last()
    const province = Random.province()
    const date = Random.date()

    customers.push({
      id,
      firstName,
      lastName ,
      province,
      date
    })
  }

  return { customers }

🧪 测试工具

Jest

Jest[17] 是一款便捷好用的 JavaScript 测试框架,以简单为核心诉求。您可以通过易于上手且功能丰富的 API 编写测试,从而快速获取结果。

jest-office

安装及示例
代码语言:javascript
复制
yarn add --dev jest

测试sum函数,这个函数的功能是两数相加。首先创建 sum.js 文件:

代码语言:javascript
复制
function sum(a, b) {
  return a + b;
}
module.exports = sum;

接下来,创建名为 sum.test.js 的文件。这个文件包含了实际测试内容:

代码语言:javascript
复制
const sum = require("./sum");

test("adds 1 + 2 to equal 3", () => {
  expect(sum(1, 2)).toBe(3);
});

将如下代码添加到 package.json 中:

代码语言:javascript
复制
{
  "script": {
    "test": "jest"
  }
}

最后,运行 yarn test ,Jest 将输出如下信息:

代码语言:javascript
复制
PASS  ./sum.test.js
✓ adds 1 + 2 to equal 3 (5ms)

Mocha

Mocha[18] 是一个功能丰富的 javascript 测试框架,运行在 node.js 和浏览器中,使异步测试变得简单有趣。Mocha 测试连续运行,允许灵活和准确的报告,同时将未捕获的异常映射到正确的测试用例。

安装及示例

代码语言:javascript
复制
yarn add mocha --dev

接下来,创建名为 test.js 的文件。这个文件包含了实际测试内容:

代码语言:javascript
复制
var assert = require("assert");

describe("Array", function () {
  describe("#indexOf()", function () {
    it("should return -1 when the value is not present", function () {
      assert.equal([1, 2, 3].indexOf(4), -1);
    });
  });
});

将如下代码添加到 package.json 中:

代码语言:javascript
复制
{
  "script": {
    "test": "mocha"
  }
}

最后,运行 yarn test ,Mocha 将输出如下信息:

代码语言:javascript
复制
$ ./node_modules/mocha/bin/mocha

  Array
    #indexOf()
      ✓ should return -1 when the value is not present


  1 passing (9ms)

👨‍💻 进程管理器与运行器

Nodemon

nodemon[19]用来监视 node.js 应用程序中的任何更改并自动重启服务,非常适合用在开发环境中。

nodemon 将监视启动目录中的文件,如果有任何文件更改,nodemon 将自动重新启动 node 应用程序。

安装及示例
代码语言:javascript
复制
yarn add  nodemon global

server.js表示一个 Node.js 入口文件

代码语言:javascript
复制
  "scripts": {
    "start": "nodemon server.js",
  }

PM2

PM2[20] 是一个具有内置负载均衡器的 Node.js 应用程序的生产流程管理器。有了它,你就可以让应用程序永远保持活跃,可以在不停机的前提下重新加载它们,并简化常见的系统管理任务。

p2-github

安装及示例
代码语言:javascript
复制
$ yarn add global pm2

你可以像下面一样启动任何应用程序(Node.js、Python、Ruby、$PATH 中的二进制文件……)

代码语言:javascript
复制
$ pm2 start app.js

现在,你的应用将被守护、监控并永远保持活跃。有关流程管理的更多信息见此[21]

应用程序启动后,你就可以轻松管理它们。可以通过以下方法列出所有正在运行的应用程序:

代码语言:javascript
复制
$ pm2 ls

查阅官方文档[22],以获取 PM2 功能给的完整列表。

Concurrently

Concurrently[23]简单而直接——可同时运行多条命令的实用工具。

Concurrently-github

安装及示例
代码语言:javascript
复制
yarn add concurrently global

时启动前端 webpack 项目和 后端 node 项目

代码语言:javascript
复制
// package.json   同
"scripts": {
    "start": "concurrently \"webpack-dev-server\" \"nodemon server.js\"",
  },

Web sockets

Socket.io

Socket.IO[24] 支持实时、双向、基于事件的通信功能。它能够运行在各类平台、浏览器及设备之上,且拥有良好的可靠性与速度表现。

Socket.io-office

安装及示例

官方教程[25]

WS

WS[26]易于使用、快速且经过全面测试的 WebSocket 客户端与服务器实现。同时也是一套强大、抽象度更低且几乎能够与 Socket.io 相媲美的替代方案。

作者:望道 https://juejin.cn/post/6950584088462163982

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-09-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端达人 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 🧰 实用工具
    • Lodash
      • 安装及示例
    • qs
      • classnames
        • 安装及示例
      • numeral
        • 安装及示例
      • cross-env
        • path-to-regexp
          • 安装及示例
      • 📅 日期格式
        • Day.js
          • 安装
          • 示例
      • 🌷 Linters 与格式化工具
        • ESLint
          • Prettier
            • 安装
            • 示例
          • stylelint
            • 安装
            • 示例
          • Husky
          • 🧙‍♂️ 数据生成器
            • Uuid
              • 安装及示例
            • faker.js
              • 安装及示例
            • Mock.js
            • 🧪 测试工具
              • Jest
                • 安装及示例
              • Mocha
                • 安装及示例
                • 👨‍💻 进程管理器与运行器
                  • Nodemon
                    • 安装及示例
                  • PM2
                    • Concurrently
                    • Web sockets
                      • Socket.io
                        • 安装及示例
                      • WS
                      相关产品与服务
                      负载均衡
                      负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
                      领券
                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档