前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue使用uuid-npm快速生成uuid,适用于多种场景

Vue使用uuid-npm快速生成uuid,适用于多种场景

作者头像
德顺
发布2023-08-25 13:48:08
1.8K0
发布2023-08-25 13:48:08
举报
文章被收录于专栏:前端资源

最近项目中需要记录访客的 UUID 以实现用户存留、日活、月活等用户画像。

首先,什么是 UUID ?

UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写,是一种软件建构的标准,亦为开放软件基金会组织在分布式计算环境领域的一部分。其目的,是让分布式系统中的所有元素,都能有唯一的辨识信息,而不需要通过中央控制端来做辨识信息的指定。

RFC 4122第3节提供UUID字符串表示形式的定义。UUID 是由一组32位数的16进制数字所构成,是故 UUID 理论上的总数为1632=2128,约等于3.4 x 10123。

也就是说若每纳秒产生1百万个 UUID,要花100亿年才会将所有 UUID 用完

格式:

UUID 的十六个八位字节被表示为 32个十六进制数字,以连字号分隔的五组来显示,形式为 8-4-4-4-12,总共有 36个字符(即三十二个英数字母和四个连字号)。例如:

代码语言:javascript
复制
123e4567-e89b-12d3-a456-426655440000
xxxxxxxx-xxxx-Mxxx-Nxxx-xxxxxxxxxxxx

数字 M 的四位表示 UUID 版本,当前规范有5个版本,M可选值为1, 2, 3, 4, 5 ;

数字 N 的一至四个最高有效位表示 UUID 变体( variant ),有固定的两位10xx因此只可能取值8, 9, a, b;

UUID版本通过 M 表示,当前规范有5个版本,可选值为1, 2, 3, 4, 5。这5个版本使用不同算法,利用不同的信息来产生 UUID,各版本有各自优势,适用于不同情景。具体使用的信息

UUID - npm

Vue 、React 等可以直接通过 npm 安装并使用 uuid。

用于创建RFC4122 UUID。

完整 -支持RFC4122版本1、3、4和5 UUID。

1、安装:

代码语言:javascript
复制
npm install uuid

2、生成一个 UUID :

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

3、使用 CommonJS 语法:

代码语言:javascript
复制
const { v4: uuidv4 } = require('uuid');
uuidv4(); // ⇨ '1b9d6bcd-bbfd-4b2d-9b5d-ab8dfbbd4bed'

API摘要 具体的API,可以去 npm 的详情页面查看。

uuid.NIL

nil UUID字符串(全零)

新进 uuid@8.3

uuid.parse()

将UUID字符串转换为字节数组

新进 uuid@8.3

uuid.stringify()

将字节数组转换为UUID字符串

新进 uuid@8.3

uuid.v1()

创建版本1(时间戳)UUID

uuid.v3()

创建版本3(带MD5的命名空间)UUID

uuid.v4()

创建版本4(随机)UUID

uuid.v5()

创建版本5(带SHA-1的命名空间)UUID

uuid.validate()

测试字符串以查看它是否为有效的UUID

新进 uuid@8.3

uuid.version()

检测UUID的RFC版本

新进 uuid@8.3

应用场景:

我们可以根据需求,来满足不用的应用场景,比如:

页面刷新即生成一个新的 UUID :

代码语言:javascript
复制
uuid.v4() //直接加在页面的任意位置

打开页面/标签,即生成一个 UUID ,页面刷新 UUID 不会变。

打开页面,如果没有 UUID 则生成一个存入 sessionStorage ,如果有则直接读取 sessionStorage 中保存的 UUID 。

代码语言:javascript
复制
let uuid = sessionStorage.getItem('uuid');
if (!uuid) {
  sessionStorage.setItem('uuid',uuidv4());
}

UUID 长期保存,清缓存后自动生成:

这样我们可以将 uuid 存入 localStorage 中,可以长期保存:

代码语言:javascript
复制
let uuid = localStorage.getItem('uuid');
if (!uuid) {
  localStorage.setItem('uuid',uuidv4());
}

增加登录验证,未登陆状态再生成 UUID:

代码语言:javascript
复制
if (getToken()){//判断是否有 token
  sessionStorage.removeItem('uuid'); //如果有,清除 sessionStorage 中的 uuid
} else {//未登录状态生成 uuid
  let uuid = sessionStorage.getItem('uuid');
  if (!uuid) {
    sessionStorage.setItem('uuid',uuidv4());
  }
}

当然,也可以根据时间、设备信息、MD5和加盐(Salt)等方式生成更加精确的 UUID,大家可以根据自己的需求灵活运用。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-08-18),如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 首先,什么是 UUID ?
  • UUID - npm
  • 应用场景:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档