随机生成hex颜色的方法(随机生成的是0到15的随机数)

1.采用Math.random()---安全性不高

export default function getRandomColor() {
  let str = '#';
  const arr = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'];
  for (let i = 0; i < 6; i++) {
    const num = parseInt(String(Math.random() * 16));
    str += arr[num];
  }
  return str;
}

2.采用new  Date()时间戳---数字重复较高,颜色比较单一

export default function getRandomColor() {
  let str = '#';
  const arr = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'];
  for (let i = 0; i < 6; i++) {
    const num = getRandomInt();
    str += arr[num];
  }
  function getRandomInt() {
    const timestamp = new Date().getTime();
    const randomNum = timestamp % 16;
    return randomNum;
  }
  return str;
}

3.Crypto API --- 使用的是浏览器内置的 Crypto API,随机性高安全性也高

我们将随机数与100取模,以得到介于0和99之间的数字。如果想生成0和15之间的数字,需要将随机数与16取模,但需要浏览器支持web Crypto API

export default function getRandomColor() {
  let str = '#';
  const arr = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'];
  for (let i = 0; i < 6; i++) {
    const cryptoArray = new Uint32Array(1);
    window.crypto.getRandomValues(cryptoArray);
    const randomValue = cryptoArray[0];
    const num = randomValue % 16;
    str += arr[num];
  }
  return str;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

文哈哈wcx

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值