比UUID更快更小更强大!NanoID唯一ID生成神器全解析

1. 为什么选择NanoID?

  • 小巧. 118字节 (经过压缩和Brotli处理)。没有依赖。Size Limit 控制大小。
  • 安全. 它使用硬件随机生成器。可在集群中使用。
  • 紧凑. 它使用比 UUID(A-Za-z0-9_-)更大的字母表。因此,ID 大小从36个符号减少到21个符号。
  • 可移植. Nano ID 已被移植到 20种编程语言

2. 快速上手:如何安装?

Node.js环境:

bash 复制代码
npm install nanoid

浏览器CDN(兼容 ESM/UMD):

html 复制代码
<script src="https://cdn.jsdelivr.net/npm/nanoid/nanoid.js"></script>

3. 生成一个唯一ID

最基本的用法,只需一行代码:

js 复制代码
import { nanoid } from 'nanoid';

const id = nanoid();
console.log(id); // 如:Kh_1OuFVecVCKfMdj1NXq
  • 默认ID 长度为21字符
  • 随机,URL安全(不会出现 + / = )

4. 自定义ID长度

觉得21字符不合适?自定义更短/更长都OK:

js 复制代码
console.log(nanoid(10));  // 10位ID,如: Y3Xh9md3Wz
console.log(nanoid(32));  // 32位ID

长度越长碰撞概率越低,如果对安全性要求极高可适当加长


5. 自定义字符集 (高级技巧)

有时候你可能需要生成仅包含数字、限定范围字符,甚至全大写/小写字母的ID。NanoID可以轻松胜任!

js 复制代码
import { customAlphabet } from 'nanoid';

// 仅数字ID
const nanoidNumber = customAlphabet('1234567890', 8);
console.log(nanoidNumber()); // 24736672

// 全大写字母+数字
const nanoidUpper = customAlphabet('ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789', 8);
console.log(nanoidUpper()); // OO8QE8V0

自定义字符集让你的ID生成100%满足业务和审美需求。


6. 批量生成唯一ID(如:批量插入数据用)

js 复制代码
import { nanoid } from 'nanoid';

const ids = Array.from({ length: 5 }, () => nanoid());
console.log(ids); // ['wr9bcsr1Te5HKEn_WYVKx','Fho3hazZDYNGWorG7APit','VIuIpbrVamSjnKMVg9IpO','3ArbZPt8qc_JL_IF8WTbJ','V9YCFTNFgaWF6hnQRgJBH']

7. 小结

NanoID是现代JavaScript唯一ID生成的最佳选择。它既高效、安全、可配置、易用,完全可以替代UUID、shortid、cuid等ID方案,真正让"唯一ID"这件事从此无忧。


如果你喜欢本教程,记得点赞+收藏!关注我获取最新JavaScript开发干货。

相关推荐
金色天际线-1 小时前
Nginx 优化与防盗链配置指南
java·后端·spring
牧羊狼的狼3 小时前
React 中的 HOC 和 Hooks
前端·javascript·react.js·hooks·高阶组件·hoc
知识分享小能手4 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
luckys.one4 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
魔云连洲4 小时前
深入解析:Vue与React的异步批处理更新机制
前端·vue.js·react.js
mCell5 小时前
JavaScript 的多线程能力:Worker
前端·javascript·浏览器
weixin_437830946 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr
超级无敌攻城狮6 小时前
3 分钟学会!波浪文字动画超详细教程,从 0 到 1 实现「思考中 / 加载中」高级效果
前端
excel7 小时前
用 TensorFlow.js Node 实现猫图像识别(教学版逐步分解)
前端
gnip8 小时前
JavaScript事件流
前端·javascript