JavaScript中的Math对象

简介:
   Math 对象

Math对象为我们提供了许多数学相关的功能,例如获得一个数字的平方或者产生一个随机数。Math对象和DateString对象有两点不同:

l         你不能显式的创建一个Math对象,你只直接使用它就可以了

l         Math对象不存储数据,和String Date对象不同

你可以按照下面的格式来调用Math对象的方法:

Math.methodOfMathObject( aNumber ):

alert( "The value of pi is " + Math.PI );

接下来我们会学习几个常用的方法(在[url]http://www.mozilla.org/docs/web-developer/[/url]上搜索一下,你会发现一个完整的参考)。在这里我们看一下舍入数字和产生随机数的方法。

   舍入数字

在前面你曾看到parseInt() 函数会通过移去小数点后面一切来使一个小数变成整数(因此24.999变为24)。经常地,你会需要更多的算术方面地精确计算,举个例子,如果你正在处理财务计算,为达到这个目的,你可以使用Math对象的三个舍入函数种的一个:round()ceil(),

floor()。下面是它们如何工作的:

l         round():当小数是.5或者大于.5的时候向上入一位。

l         ceil() 始终向上舍入,因此23.75变为24, 23.25也是如此。

l         floor()始终向下舍入,因此23.75变为23, 23.25也是如此。

这里通过一个简单的例子来看看它们是如何工作的:

<html>

<body>

<script type="text/javascript">

var numberToRound = prompt( "Please enter a number", "" )

document.write( "round( ) = " + Math.round( numberToRound ) );

document.write( "<br>" );

document.write( "floor( ) = " + Math.floor( numberToRound ) );

document.write( "<br>" );

document.write( "ceil( ) = " + Math.ceil( numberToRound ) );

</script>

</body>

</html>

尽管我们使用prompt()从用户那里获取一个值,我们前面看到会返回一个字符串,但是返回的数仍然会被当作一个数字来对待。这是因为只要字符串中包含能被转换为数字的东西,舍入函数就会为我们进行转换。

如果我们输入23.75我们会得到如下的结果:

                                                                                 

 

round() = 24

floor() = 23

ceil() = 24

                                                                                 

如果我们输入-23.75,我们得到

                                                                                 

 

round() = -24

floor() = -24

ceil() = -23

                                                                                 

 

   产生一个随机数

你可以使用Math对象的random()方法,产生一个大于等于0但小于得随机小数。 通常为了利用它,你需要乘以某个数,然后再使用其中的一个舍入方法。

举个例子,为了模拟一次掷骰子,我们需要产生一个16之间的一个随机数,我们可以通过把随机小数乘以5,获得05之间的一个小数,接着使用round()方法对这个小数进行四舍五入得到一个整数。(我们不能乘以6,然后每次使用ceil()方法向上舍入,因为那样会偶然地得到0。)然后我们获得了一个05之间的整数,所以通过加1,我们就能得到一个16之间的数。这种方法不能给我们模拟一个完美的掷骰子,但是对于大多数的目的都足够了。 下面是这段代码:

<html>

<body>

<script type="text/javascript">

var diceThrow = Math.round( Math.random( ) * 5 ) + 1;

document.write( "You threw a " + diceThrow );

</script>

</body>

</html>









本文转自 牛海彬 51CTO博客,原文链接:http://blog.51cto.com/newhappy/76827,如需转载请自行联系原作者
目录
相关文章
|
3天前
|
存储 JavaScript 索引
js开发:请解释什么是ES6的Map和Set,以及它们与普通对象和数组的区别。
ES6引入了Map和Set数据结构。Map的键可以是任意类型且有序,与对象的字符串或符号键不同;Set存储唯一值,无重复。两者皆可迭代,支持for...of循环。Map有get、set、has、delete等方法,Set有add、delete、has方法。示例展示了Map和Set的基本操作。
17 3
|
15天前
|
JavaScript
JS 获取对象数据类型的键值对的键与值
JS 获取对象数据类型的键值对的键与值
|
25天前
|
JavaScript 前端开发
Math对象:JavaScript中的数学工具
Math对象:JavaScript中的数学工具
27 1
N..
|
1月前
|
存储 JavaScript 前端开发
JavaScript中的对象
JavaScript中的对象
N..
10 0
|
1月前
|
JavaScript 前端开发
JavaScript对象系列(菜菜出品,必看!!!)
JavaScript对象系列(菜菜出品,必看!!!)
|
2月前
|
JavaScript 前端开发
JS将两个数组和合并成数组包对象格式的方法
JS将两个数组和合并成数组包对象格式的方法
28 0
|
18天前
|
JavaScript 算法
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
|
1月前
|
存储 JavaScript 前端开发
在JavaScript中,对象和数组是如何进行扩展的?
在JavaScript中,对象和数组是如何进行扩展的?
22 4
|
4天前
|
JavaScript 前端开发 开发者
JavaScript中的错误处理:try-catch语句与错误对象
【4月更文挑战第22天】JavaScript中的错误处理通过try-catch语句和错误对象实现。try块包含可能抛出异常的代码,catch块捕获并处理错误,finally块则无论是否出错都会执行。错误对象提供关于错误的详细信息,如类型、消息和堆栈。常见的错误类型包括RangeError、ReferenceError等。最佳实践包括及时捕获错误、提供有用信息、不忽略错误、利用堆栈信息和避免在finally块中抛错。
|
10天前
|
JavaScript
【Js】检查Date对象是否为Invalid Date
【Js】检查Date对象是否为Invalid Date
14 0