js生成随机数的过程解析


Posted in Javascript onNovember 24, 2015

一、预备知识

Math.ceil(); //向上取整。

Math.floor(); //向下取整。

Math.round(); //四舍五入。

Math.random(); //0.0 ~ 1.0 之间的一个伪随机数。【包含0不包含1】 //比如0.8647578968666494

Math.ceil(Math.random()*10);   // 获取从1到10的随机整数 ,取0的概率极小。

Math.round(Math.random());  //可均衡获取0到1的随机整数。

Math.floor(Math.random()*10); //可均衡获取0到9的随机整数。

Math.round(Math.random()*10); //基本均衡获取0到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);

以上就是关于js生成随机数的全面解析,很细致,希望可以帮到大家。

Javascript 相关文章推荐
Microsfot .NET Framework4.0框架 安装失败的解决方法
Aug 14 Javascript
javascript事件委托的方式绑定详解
Jun 10 Javascript
javascript实现网站加入收藏功能
Dec 16 Javascript
安装使用Mongoose配合Node.js操作MongoDB的基础教程
Mar 01 Javascript
关于Jquery中的bind(),on()绑定事件方式总结
Oct 26 Javascript
vue-router单页面路由
Jun 17 Javascript
Bootstrap datepicker日期选择器插件使用详解
Jul 26 Javascript
使用JS中的Replace()方法遇到的问题小结
Oct 20 Javascript
MVVM 双向绑定的实现代码
Jun 21 Javascript
Vue 组件封装 并使用 NPM 发布的教程
Sep 30 Javascript
详解三种方式解决vue中v-html元素中标签样式
Nov 22 Javascript
微信小程序实现获取用户信息并存入数据库操作示例
May 07 Javascript
jquery制作图片时钟特效
Mar 30 #Javascript
jQuery实现Tab选项卡切换效果简单演示
Nov 23 #Javascript
JS鼠标拖拽实例分析
Nov 23 #Javascript
基于jQuery实现简单的折叠菜单效果
Nov 23 #Javascript
jquery无限级联下拉菜单简单实例演示
Nov 23 #Javascript
jquery实现图片放大镜功能
Nov 23 #Javascript
jquery自定义表格样式
Nov 23 #Javascript
You might like
JoshChen_php新手进阶高手不可或缺的规范介绍
2013/08/16 PHP
详解thinkphp实现excel数据的导入导出(附完整案例)
2016/12/29 PHP
php微信公众号开发之简答题
2018/10/20 PHP
jquery.validate使用攻略 第二部
2010/07/01 Javascript
UpdatePanel和Jquery冲突的解决方法
2013/04/01 Javascript
JS实现一键回顶功能示例代码
2013/10/28 Javascript
js/jQuery简单实现选项卡功能
2014/01/02 Javascript
javascript数组输出的两种方式
2015/01/13 Javascript
jQuery中attr()与prop()函数用法实例详解(附用法区别)
2015/12/29 Javascript
jQuery模仿阿里云购买服务器选择购买时间长度的代码
2016/04/29 Javascript
Vue 源码分析之 Observer实现过程
2018/03/29 Javascript
vue实现组件之间传值功能示例
2018/07/13 Javascript
微信小程序实现pdf、word等格式文件上传的方法
2019/09/10 Javascript
layui下拉列表select实现可输入查找的方法
2019/09/28 Javascript
VUE:vuex 用户登录信息的数据写入与获取方式
2019/11/11 Javascript
JavaScript 几种循环方式以及模块化的总结
2020/09/03 Javascript
[07:40]DOTA2每周TOP10 精彩击杀集锦vol.4
2014/06/25 DOTA
python入门之语句(if语句、while语句、for语句)
2015/01/19 Python
python中的闭包用法实例详解
2015/05/05 Python
详解Python中heapq模块的用法
2016/06/28 Python
Python编码类型转换方法详解
2016/07/01 Python
python实现生命游戏的示例代码(Game of Life)
2018/01/24 Python
解决python写入带有中文的字符到文件错误的问题
2019/01/31 Python
Python将视频或者动态图gif逐帧保存为图片的方法
2019/09/10 Python
Python基于BeautifulSoup爬取京东商品信息
2020/06/01 Python
Python调用SMTP服务自动发送Email的实现步骤
2021/02/07 Python
Charlotte Tilbury英国官网:英国彩妆品牌
2017/05/26 全球购物
Speedo速比涛法国官方网站:泳衣、泳镜、泳帽、泳裤
2019/07/30 全球购物
Linux中如何设置Java环境变量(Ubuntu)
2016/07/24 面试题
财务副总经理工作职责
2013/11/25 职场文书
高中同学聚会邀请函
2014/01/11 职场文书
大学理论知识学习自我鉴定
2014/04/28 职场文书
金融系应届毕业生求职信
2014/05/26 职场文书
五星级酒店宣传口号
2015/12/25 职场文书
jupyter notebook保存文件默认路径更改方法汇总(亲测可以)
2021/06/09 Python
Python字符串的转义字符
2022/04/07 Python