点击右上方红色按钮关注“web秀”,让你真正秀起来
前言最近在头条也是给小伙伴们送出3.8福利,由于是小用户,头条也没有给出抽奖活动的功能,所以必须自己来一个,顺道补充一下JS随机数的小知识。结尾附上本次抽奖代码,一次抽出中奖者,明天(3.8)12:00公布结果,也是第一次做出这样的活动,感谢大家的支持。没有参与的小伙伴还有一天时间,希望大家可以参与。
JavaScript生成随机数, 来个抽奖活动
基础知识向上取整
Math.ceil();// 示例Math.ceil(1.5); // 2Math.ceil(2.4); // 3
向下取整
Math.floor();// 示例Math.floor(1.2); // 1Math.floor(0.5); // 0
四舍五入
Math.round();// 示例Math.round(1.2); // 1Math.round(0.5); // 1
0.0 ~ 1.0 之间的一个伪随机数。【包含0不包含1】
Math.random(); // 0.8647578968666494
获取从1到10的随机整数
Math.ceil(Math.random()*10); // 取0的概率极小。
均衡获取0到1的随机整数
Math.round(Math.random());
均衡获取0到9的随机整数
Math.floor(Math.random()*10);
均衡获取0到10的随机整数
Math.round(Math.random()*10); // 其中获取最小值0和最大值10的几率少一半。因为结果在0~0.4 为0,0.5到1.4为1...8.5到9.4为9,9.5到9.9为10。所以头尾的分布区间只有其他数字的一半。
生成[n,m]的随机整数函数功能:生成[n,m]的随机整数。 在js生成验证码或者随机选中一个选项时很有用
//生成从minNum到maxNum的随机数function randomNum(minNum,maxNum){ switch(arguments.length){ case 1: return parseInt(Math.random()*minNum 1,10); break; case 2: return parseInt(Math.random()*(maxNum-minNum 1) minNum,10); break; default: return 0; break; }}
解析
Math.random() 生成[0,1)的数,所以
Math.random()*5 生成{0,5)的数。
通常期望得到整数,所以要对得到的结果处理一下。
parseInt(),Math.floor(),Math.ceil()和Math.round()都可得到整数。
parseInt()和Math.floor()结果都是向下取整。
所以Math.random()*5生成的都是[0,4]的随机整数。
所以生成[1,max]的随机数,公式如下:
// max - 期望的最大值parseInt(Math.random()*max,10) 1;Math.floor(Math.random()*max) 1;Math.ceil(Math.random()*max);
所以生成[0,max]到任意数的随机数,公式如下:
// max - 期望的最大值parseInt(Math.random()*(max 1),10);Math.floor(Math.random()*(max 1));
所以希望生成[min,max]的随机数,公式如下:
// max - 期望的最大值// min - 期望的最小值parseInt(Math.random()*(max-min 1) min,10);Math.floor(Math.random()*(max-min 1) min);
3.8抽奖代码// 随机数函数function randomNum(minNum,maxNum){ switch(arguments.length){ case 1: return parseInt(Math.random()*minNum 1,10); break; case 2: return parseInt(Math.random()*(maxNum-minNum 1) minNum,10); break; default: return 0; break; }}// 参与抽奖人员let personnel = ['程序陈', 'huyu2019', '一枝梅花斗风雪', 'Qin琴子', '骑蜗牛追导弹35502946', '橙野儿', ...];let luckyIndex = randomNum(0, personnel.length);let luckyName = personnel[luckyIndex];console.log('恭喜 ' luckyName ' 中奖,谢谢您的支持');