实现随机数是各种编程语言都很常见的一个编程任务,下面介绍一下在JavaScript如何实现随机数。非常的简单实用的例子奉献给大家,希望大家能够喜欢。 今天有又网友问到我 JavaScript 怎么生成指定范围数值随机数。Math.random() 这个方法相信大家都知道,是用来生成随机数的。不过一般的参考手册时却没有说明如何用这个方法来生成指定范围内的随机数。这次我就来详细的介绍一下Math.random(),以及如何用它来生成制定范围内的随机数。
利用 parseInt()、Math.floor() 或者 Math.ceil()进行四舍五入处理 我们看到,直接使用Math.random()方法,生成的是一个小于1的数,所以: 得到的结果是一个小于5的随机数。而我们通常希望得到的是0-5之间的整数,所以我们需要对得到的结果四舍五入处理一下,从而得到我们期望的整数。parseInt()、Math.floor()和Math.ceil()都可以起到四舍五入的作用。 1 2 3 4 5 | var randomNum = Math.random()*5; alert(randomNum); alert(parseInt(randomNum,10)); alert(Math.floor(randomNum)); alert(Math.ceil(randomNum)); | 由测试的代码我们可以看到,parseInt()和Math.floor()的效果是一样的,都是向下取整数部分。所以parseInt(Math.random()*5,10)和Math.floor(Math.random()*5)都是生成的0-4之间的随机数,Math.ceil(Math.random()*5)则是生成的1-5之间的随机数。 生成指定范围数值随机数 所以,如果你希望生成1到任意值的随机数,公式就是这样的: 1 2 3 4 | parseInt(Math.random()*max,10)+1; Math.floor(Math.random()*max)+1; Math.ceil(Math.random()*max); | 如果你希望生成0到任意值的随机数,公式就是这样的: 1 2 3 | parseInt(Math.random()*(max+1),10); Math.floor(Math.random()*(max+1)); | 如果你希望生成任意值到任意值的随机数,公式就是这样的: 1 2 3 4 | parseInt(Math.random()*(max-min+1)+min,10); Math.floor(Math.random()*(max-min+1)+min); | 下面我们来看看javascript生成随机数的其他方法 1.使用内置的随机数发生方法:(刚刚讲过,这里简单描述下) 1 2 3 | Math.random(); Math.floor(Math.random()*10+1); Math.floor(Math.random()*24); | 2.基于时间,亦可以产生随机数: 代码如下: var now=new Date(); var number = now.getSeconds(); //这将产生一个基于目前时间的0到59的整数。 var now=new Date(); var number = now.getSeconds()%43; //这将产生一个基于目前时间的0到42的整数。 3.一个相当优秀的的随机数发生器程序,能应用于许多领域。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | <script language= "JavaScript" ><!-- rnd.today= new Date(); rnd.seed=rnd.today.getTime(); function rnd() { rnd.seed = (rnd.seed*9301+49297) % 233280; return rnd.seed/(233280.0); }; function rand(number) { return Math.ceil(rnd()*number); }; </script> | 我们再来看2个具体的实例吧, 第一种方法通过重写Math.random方法实现,第二种方法改自一个C实现,都可以实现编程目的。 实例一: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | <script language= "javascript" > var native_random = Math.random; Math.random = function (min, max, exact) { if (arguments.length === 0) { return native_random(); } else if (arguments.length === 1) { max = min; min = 0; } var range = min + (native_random()*(max - min)); return exact === void(0) ? Math.round(range) : range.toFixed(exact); }; document.write(Math.random()); document.write( '<br />' ); document.write(Math.random(10)); document.write( '<br />' ); document.write(Math.random(3,10)); document.write( '<br />' ); document.write(Math.random(2,10,4)); </script> | 实例二: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | <script type= "text/javascript" > var random = ( function (){ var high = 1, low = 1 ^ 0x49616E42; var shuffle = function (seed){ high = seed; low = seed ^ 0x49616E42; } return function (){ var a = new Date()-0 shuffle(a); high = (high << 16) + (high >> 16); high += low; low += high; return high; } })(); alert( random() ); </script> | 好了,通过这些例子,大家应该对javascript生成随机数有了相应的了解,希望本文能够给大家一些启发。
另: 通过JavaScript的Math.random()方法可以获取0到1之间的任意随机数,那如何获取任意给定的两个数之间的随机数呢?如获取2和5之间的随机数,5和10之间的随机数等。 由于Math.random()函数总是返回0到1之间的一个随机数,我们可以把0看成最小数,把1看成最大数。假设最小数是max,最大数是min,通过下面的公式我们便可得出任意两个数之间的随机数: Math.random() * (max - min) + min 如果使用Math.floor()进行向下舍入操作,则需要将max - min + 1,即: Math.floor(Math.random() * (max - min) + min) 如果要指定小数位数,可以使用Math.round()函数。如下面的公式返回任意两个整数之间的随机数,结果保留1位小数: Math.round((Math.random() * (max - min) + min) * 10) / 10
具体实例(下面二个都是生成80到130的随机数): <script type="text/javascript"> document.write(Math.floor(Math.random()*(51)+80)); </script>
<script type="text/javascript"> document.write(parseInt(Math.random()*(51)+80,10)); </script>
|