浅谈JavaScript Math和Number对象


Posted in Javascript onJanuary 26, 2015

1. Math 对象

1.1 介绍

Math 对象,是数学对象,提供对数据的数学计算,如:获取绝对值、向上取整等。无构造函数,无法被初始化,只提供静态属性和方法。

1.2 构造函数

无 :Math 对象无构造函数,无法被初始化,只提供静态属性和方法。

1.3 静态属性

1.3.1 Math.E :常量e。返回自然对数的底数:2.718281828459045
 
1.3.2 Math.PI :常量π。返回圆周率的值 :3.141592653589793
 
1.4 静态方法

1.4.1 Math.sin(value) :正弦函数
1.4.2 Math.cos(value) :余弦函数
1.4.3 Math.tan(value) :正切函数
1.4.4 Math.asin(value) :反正弦函数
1.4.5 Math.acos(value) :反余弦函数
1.4.6 Math.atan(value) :反正切函数
1.4.7 Math.abs(value) :返回绝对值

参数:
 
①value {Number | NumberStr} :数字或者纯数字的字符串。
 
返回值:
 
{Number} 返回参数的绝对值数字。若参数不为数字,返回NaN。
 
示例:

h.abs('123'); // => 123 :纯数字字符串

Math.abs('-123'); // => 123

Math.abs(123); // => 123

Math.abs(-123); // => 123

Math.abs('123a'); // => NaN :非纯数字字符串

1.4.8  Math.ceil(value) : 对一个数向上取整,并不是四舍五入
参数:
 
①value {Number | NumberStr} :数字或者纯数字的字符串。
 
返回值:
 
{Number} 返回取整后的值。若参数不为数字,返回NaN。
 
示例:
 

Math.ceil(2.7); // => 3

Math.ceil(2.3); // => 3 :2.3 向上取整返回 3

Math.ceil(-2.7); // => -2

Math.ceil(-2.3); // => -2

Math.ceil('2.7'); // => 3 :纯数字字符串

Math.ceil('2.7a'); // => NaN :非纯数字字符串

 
1.4.9 Math.floor(value) :对一个数向下取整,并不是四舍五入
参数:
 
①value {Number | NumberStr} :数字或者纯数字的字符串。
 
返回值:
 
{Number} 返回取整后的值。若参数不为数字,返回NaN。
 
示例:
Math.floor(2.7); // => 2

Math.floor(2.3); // => 2

Math.floor(-2.7); // => -3 :-2.7 向下取整返回 -3

Math.floor(-2.3); // => -3

Math.floor('2.7'); // => 2 :纯数字字符串

Math.floor('2.7a'); // => NaN :非纯数字字符串

 
1.4.10 Math.max(value1,value2...valueN) :返回参数中最大的值
参数:
 
①value1,value2.....valueN {Number | NumberStr} :数字或者纯数字的字符串。
 
返回值:
 
{Number} 返回最大值。若一个参数不为数字,返回NaN。
 
示例:
 
Math.max(1, 2, 3, 4, 5); // => 5

Math.max(1, 2, 3, 4, '5' ); // => 5

Math.max(1, 2, 3, 4, 'a'); // => NaN

 
1.4.11 Math.min(value1,value2...valueN) :返回参数中最小的值
参数:
 
①value1,value2.....valueN {Number | NumberStr} :数字或者纯数字的字符串。
 
返回值:
 
{Number} 返回最大值。若一个参数不为数字,返回NaN。
 
示例:
 

Math.min(1, 2, 3, 4, 5); // => 1

Math.min('1', 2, 3, 4, 5); // => 1

Math.min(1, 2, 3, 4, 'a'); // => NaN

 
1.4.12 Math.pow(x,y) :返回x的y次方
参数:
 
①x {Number | NumberStr} :数字或者纯数字的字符串。
 
②y {Number | NumberStr} :数字或者纯数字的字符串。
 
返回值:
 
{Number} 返回x的y次方。若一个参数不为数字,返回NaN。
 
示例:
Math.pow(2, 3); // => 8 :2的3次方

Math.pow(3, 2); // => 9 :3的2次方

Math.pow('4', 2); // => 16 :4的2次方

Math.pow('2a', 2); // => NaN

 
1.4.13 Math.random() :返回一个伪随机数,大于0,小于1.0
参数:无
 
返回值:
 
{Number} 返回一个伪随机数,大于0,小于1.0
 
示例:
Math.random(); // => 0.8982374747283757

Math.random(); // => 0.39617531932890415

Math.random(); // => 0.35413061641156673

Math.random(); // => 0.054441051790490746

 
1.4.14 Math.round(value) : 四舍五入后取整
参数:
 
①value {Number | NumberStr} :数字或者纯数字的字符串。
 
返回值:
 
{Integer} 返回参数四舍五入后的整数。若参数不为数字,返回NaN。
 
示例:
 
Math.round(2.5); // => 3

Math.round(2.4); // => 2

Math.round(-2.6); // => -3

Math.round(-2.5); // => -2 :-2.5四舍五入为 -2

Math.round(-2.4); // => -2

Math.round('2.7'); // => 3 :纯数字字符串

Math.round('2.7a'); // => NaN :非纯数字字符串

 
1.4.15 Math.sqrt(value) :返回参数的平方根
参数:
 
①value {Number | NumberStr} :数字或者纯数字的字符串
 
返回值:
 
{Number} 返回参数的平方根
 
示例:
 
console.log( Math.sqrt(9) ); // => 3

console.log( Math.sqrt(16) ); // => 4

console.log( Math.sqrt('25') ); // => 5

console.log( Math.sqrt('a') ); // => NaN

2. Number 对象

2.1 介绍
 

Number 对象,是数字对象,包含js中的整数、浮点数等等。

2.2 定义
 

var a = 1;

var b = 1.1;

2.3 静态属性
 
2.3.1 Number.MAX_VALUE :表示JS中最大的数字,约为 1.79e+308
 
2.3.2 Number.MIN_VALUE :表示JS中最小的数字,约为 5e-324
 
2.3.3 Number.NaN :返回NaN,表示非数字值,与任意其他数字不等,也包括NaN本身。应使用Number.isNaN() 来进行判断。
 
2.3.4 Number.NEGATIVE_INFINITY :返回 -Infinity ,表示负无穷。
 
2.3.5 Number.POSITIVE_INFINITY  :返回 Infinity ,表示正无穷。进行计算的值大于Number.MAX_VALUE就返回 Infinity 。
 
2.4 静态方法
 
2.4.1 Number.isInteger(value) :判断参数是否为整数
参数:
 
①value {Number} :数字
 
返回值:
 
{Boolean} 返回参数是否为整数 。纯整数的字符串也返回false。
 
示例:
 

Number.isInteger(1); // => true

Number.isInteger(1.1); // => false

Number.isInteger('1'); // => false :纯整数的字符串也返回false

Number.isInteger('1.1'); // => false

Number.isInteger('a'); // => false :非字符串返回false

 
2.4.2 Number.isNaN(value) :判断参数是否为NaN
参数:
 
①value {Object} :任意类型
 
返回值:
 
{Boolean} 返回参数是否为NaN 。
 
示例:
 
Number.isNaN(NaN); // => true

Number.isNaN('NaN'); // => false :'NaN'字符串,并不为NaN

Number.isNaN(1); // => false

Number.isNaN('1'); // => false

 
2.4.3 Number.parseFloat(value) :把参数转换为浮点数
参数:
 
①value {Number | NumberStr} :数字或者纯数字的字符串
 
返回值:
 
{Integer | Float} 返回整数或浮点数数值
 
示例:
 
Number.parseFloat(1); // => 1 :整数还是返回整数

Number.parseFloat(1.1); // => 1.1

Number.parseFloat('1aaa'); // => 1 :字符串前面为数字的,只返回数字

Number.parseFloat('1.1aaa'); // => 1.1

Number.parseFloat('a1'); // => NaN :非数字开头,返回NaN

Number.parseFloat('a'); // => NaN

 
2.4.4 Number.parseInt(value) :把参数转换为整数
参数:
 
①value {Number | NumberStr} :数字或者纯数字的字符串
 
返回值:
 
{Integer} 返回整数数值
 
示例:
 
Number.parseInt(1); // => 1

Number.parseInt(1.1); // => 1 :浮点数返回整数

Number.parseInt('1aaa'); // => 1 :字符串前面为数字的,只返回数字

Number.parseInt('1.1aaa'); // => 1

Number.parseInt('a1'); // => NaN :非数字开头,返回NaN

Number.parseInt('a'); // => NaN

2.5 实例方法
 
2.5.1 toExponential(value) :将一个数字转为指数类型,参数表示小数点后的位数
参数:
 
①value {Number}  :表示小数点后的位数
 
返回值:
 
{String} 返回转换后的指数类型字符串
 
示例:
 

(123456789).toExponential(2); // => 1.23e+8 :小数点2位

(123456789).toExponential(5); // => 1.23457e+8 :小数点5位

(123456789).toExponential(10); // => 1.2345678900e+8 :小数点10位,不足位数用0补位

 
2.5.2 toFixed(value) :将一个数字转换为指定小数位数的字符串。不传入参数,就是没小数位。返回值为四舍五入
参数:
 
①value {Number}  :表示小数点后的位数
 
返回值:
 
{String} 返回转换后的字符串;不够小数位以0填充;返回值为四舍五入后的值
 
示例:
 
console.log((1).toFixed(2)); // => 1.00

console.log((1.2).toFixed(2)); // => 1.20 :不足位数,以0补位

console.log((1.277).toFixed(2)); // => 1.28 :进行了四舍五入

 
2.5.3 toString() :使用指定的进制,将一个数字转换为字符串。不传入参数,默认为十进制。
参数:
 
①value {Number}  :表示进制数,取值范围:2到36
 
返回值:
 
{String} 转换后进制的字符串
 
示例:
 
(10).toString(); // => 10 :默认为十进制

(10).toString(2); // => 1010 :二进制

(10).toString(10); // => 10 :十进制

(10).toString(16); // => a :十六进制

2.6 应用场景

2.6.1 浮点数的加减乘除异常
说明:Js中的2个浮点数进行加减乘除运算,会返回异常的数值,如:0.2+0.7,返回0.899999999999。可以使用toFixed()方法,指定小数位。
 
示例:
 

console.log(0.2 + 0.7); // => 0.8999999999999999

console.log(0.7 - 0.5); // => 0.19999999999999996

console.log(3.03 * 10); // => 30.299999999999997

// 使用toFixed()方法

console.log( (0.2 + 0.7).toFixed(2) ); // => 0.90

console.log( (0.7 - 0.5).toFixed(2) ); // => 0.20 

console.log( (3.03 * 10).toFixed(2) ); // => 30.30

 
2.6.2 减法运算
说明:Js中进行减法运算时,会先把前后的值转换为数值再进行运算。若转换失败,返回NaN。
 
示例:
 
console.log('1' - 0); // => 1 :纯数字字符串减去0,可以快速转换为Nubmer对象

console.log( ('1' - 0).toFixed(2) ); // => 1.00 :快速转换为Nubmer对象后调用实例方法

console.log('1' - 'a'); // => NaN :一方无法转换为Nubmer对象
Javascript 相关文章推荐
JavaScript性能优化 创建文档碎片(document.createDocumentFragment)
Jul 13 Javascript
一个简单的jQuery计算器实现了连续计算功能
Jul 21 Javascript
浅谈JavaScript函数节流
Dec 09 Javascript
跟我学习javascript的prototype使用注意事项
Nov 17 Javascript
javascript高级编程之函数表达式 递归和闭包函数
Nov 29 Javascript
javascript显示上周、上个月日期的处理方法
Feb 03 Javascript
Node.js操作mysql数据库增删改查
Mar 30 Javascript
jQuery实现的自动加载页面功能示例
Sep 04 Javascript
JavaScript实现页面定时刷新(定时器,meta)
Oct 12 Javascript
jQuery实现可编辑表格并生成json结果(实例代码)
Jul 19 jQuery
vue中引入mxGraph的步骤详解
May 17 Javascript
通过实例了解Render Props回调地狱解决方案
Nov 04 Javascript
js判断一个字符串是否包含一个子串的方法
Jan 26 #Javascript
javascript中Object使用详解
Jan 26 #Javascript
JQuery中的事件及动画用法实例
Jan 26 #Javascript
javascript折半查找详解
Jan 26 #Javascript
JavaScript数据类型检测代码分享
Jan 26 #Javascript
浅谈Javascript中的Function与Object
Jan 26 #Javascript
javascript实现动态加载CSS
Jan 26 #Javascript
You might like
PHPMailer安装方法及简单实例
2008/11/25 PHP
如何解决PHP无法实现多线程的问题
2015/09/25 PHP
thinkPHP多表查询及分页功能实现方法示例
2017/07/03 PHP
PHP简单实现二维数组赋值与遍历功能示例
2017/10/19 PHP
php实现每日签到功能
2018/11/29 PHP
不错的JS中变量相关的细节分析
2007/08/13 Javascript
jQuery Ajax之load()方法
2009/10/12 Javascript
JavaScript中圆括号()和方括号[]的特殊用法疑问解答
2013/08/06 Javascript
JS实现根据出生年月计算年龄
2014/01/10 Javascript
node.js中的buffer.copy方法使用说明
2014/12/14 Javascript
jQuery动画与特效详解
2015/02/01 Javascript
浅谈jquery.fn.extend与jquery.extend区别
2015/07/13 Javascript
基于JavaScript实现全选、不选和反选效果
2017/02/15 Javascript
jQuery插件HighCharts绘制2D柱状图、折线图和饼图的组合图效果示例【附demo源码下载】
2017/03/09 Javascript
Node.js+jade+mongodb+mongoose实现爬虫分离入库与生成静态文件的方法
2017/09/20 Javascript
ES6中Array.includes()函数的用法
2017/09/20 Javascript
JavaScript 保护变量不被随意修改的实现代码
2017/09/27 Javascript
了解javascript中let和var及const关键字的区别
2019/05/24 Javascript
jquery+ajax实现上传图片并显示上传进度功能【附php后台接收】
2019/06/06 jQuery
解决layUI的页面显示不全的问题
2019/09/20 Javascript
Vue移动端用淘宝弹性布局lib-flexible插件做适配的方法
2020/05/26 Javascript
[45:52]2018DOTA2亚洲邀请赛 4.1小组赛 A组加赛 LGD vs Liquid
2018/04/02 DOTA
python 3.3 下载固定链接文件并保存的方法
2018/12/18 Python
PyCharm 配置远程python解释器和在本地修改服务器代码
2019/07/23 Python
使用matlab 判断两个矩阵是否相等的实例
2020/05/11 Python
从0到1使用python开发一个半自动答题小程序的实现
2020/05/12 Python
Django serializer优化类视图的实现示例
2020/07/16 Python
python使用matplotlib:subplot绘制多个子图的示例
2020/09/24 Python
python查询MySQL将数据写入Excel
2020/10/29 Python
味多美官网:蛋糕订购,100%使用天然奶油
2017/11/10 全球购物
华为的Java面试题
2014/03/07 面试题
工程测量与监理专业应届生求职信
2013/11/27 职场文书
后进生转化工作制度
2014/01/17 职场文书
教师培训学习心得体会
2016/01/21 职场文书
Go遍历struct,map,slice的实现
2021/06/13 Golang
Vue.Draggable实现交换位置
2022/04/07 Vue.js