记录下与Math有关的常用方法,如:求最大值、最小值等,或者是保留几位数啥的

1.数据

let floatA = 2.325232;
let floatB = 2.3456;
let temporaryArray = [1, 2, 5, 6, 3];
let minusNum = -12;
let minusFloat = -12.321;
let intA = 10;
let min, max, num;

2.求最大值、最小值

{
/* 求最小值 */
min = Math.min(floatA, floatB);
console.log(min);
/* 使用apply来重新绑定this */
min = Math.min.apply(null, temporaryArray);
console.log(min);
/* 使用展开运算符 */
min = Math.min(...temporaryArray);
console.log(min); /* 求最大值 */
max = Math.max(floatA, floatB);
console.log(max);
/* 使用apply来重新绑定this */
max = Math.max.apply(null, temporaryArray);
console.log(max);
/* 使用展开运算符 */
max = Math.max(...temporaryArray);
console.log(max);
}

3.取整

{
/* 四舍五入取整:取与参数最接近的整数 */
num = Math.round(floatA);
console.log(num); num = Math.round(minusFloat);
console.log(num); /* 向上取整:取大于或等于函数参数,并且与之最接近的整数 */
num = Math.ceil(floatB);
console.log(num); /* 向下取整:取小于或等于函数参数,并且与之最接近的整数 */
num = Math.floor(floatB);
console.log(num); /* ceil、floor结合起来,实现一个总是返回数值的整数部分的函数 */
function getInteger(value) {
value = Number(value);
return value < 0 ? Math.ceil(value) : Math.floor(value);
}
console.log(getInteger(-2.3322));
}

4.求绝对值

{
/* 负整数 */
num = Math.abs(minusNum);
console.log(num); /* 负浮点数 */
num = Math.abs(minusFloat);
console.log(num);
}

5.次幂

{
/* 结果是虚数或负数,则该方法将返回 NaN
* 如果由于指数过大而引起浮点溢出,则该方法将返回 Infinity
*/
/* 2的3次方 */
num = Math.pow(2, 3);
console.log(num);
}

6.去平方根

{
/* 求参数的平方根,如果参数小于 0,则返回 NaN */
num = Math.sqrt(9);
console.log(num);
}

7.生成随机数

{
/* 生成0-1的随机数,大于0小于1 */
num = Math.random();
console.log(num); /* 生成0-10的随机数 */
num = Math.random() * 10;
console.log(num); /* 生成任意范围随机数 */
function getRandom(min, max) {
return Math.random() * (max - min) + min;
}
console.log(getRandom(3.5, 6.5)); /* 整数min与整数max生成任意范围整数随机数 */
function getRandomInt(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}
console.log(getRandomInt(5, 15));
}

8.es6中对Math方法的扩展(部分)

{
/* 取整(非四舍五入)
* 对于非数值,内部调用 Number 强转为数值
* 对于空值或其他数据,返回NaN
* */
num = Math.trunc(floatA);
console.log(num); num = Math.trunc(intA);
console.log(num); num = Math.trunc('aaa');
console.log(num);
} {
/* 判断一个数是正数、负数或零
* 正数返回+1,负数返回-1,零返回0或-0
* 其他值 NaN
* */
num = Math.sign(2);
console.log(num); num = Math.sign(0);
console.log(num); num = Math.sign(-0);
console.log(num); num = Math.sign(-14);
console.log(num); num = Math.sign('ss');
console.log(num);
} {
let a = 2;
a **= 3;
/* 相当于 a*a*a */
console.log(a);
}

9.保留位数操作

{
/* 四舍五入保留两位小数
* toFixed(num) 方法可把 Number型 四舍五入为指定小数位数的数字
* num规定小数的位数,是 0 ~ 20 之间的值,包括 0 和 20
* 有些实现可以支持更大的数值范围,如果省略了该参数,将用 0 代替
* */
num = floatA.toFixed(2);
console.log(num); let word = 2.5;
num = word.toFixed();
console.log(num); /* 不四舍五入 */
num = Math.floor(23.365125 * 100) / 100;
console.log(num);
}

10.字符串转数字

 {
/* parseInt(value, radix)
* 用于解析字符串,返回一个整数
* radix表示要解析的数字的基数,该值介于 2 ~ 36 之间
* 如果省略该参数或其值为 0,则数字将以 10 为基础来解析
* 如果它以 “0x” 或 “0X” 开头,将以 16 为基数
* 如果该参数小于 2 或者大于 36,则 parseInt() 将返回 NaN。
* */
let temporaryString = '123';
num = parseInt(temporaryString);
console.log(num); {
console.log(parseInt("10")); //返回 10
console.log(parseInt("19",10)); //返回 19 : 10 + 9
console.log(parseInt("11",2)); //返回 3 : 2 + 1
console.log(parseInt("17",8)); //返回 15 : 8 + 7
console.log(parseInt("1f",16)); //返回 31 : 16 + 15
console.log(parseInt("010")); //未定:返回 10 或 8
} /* 常见的parseInt一道题 */
{
console.log(['1', '2', '3'].map(parseInt)); /* 返回[1, NaN, NaN]
* map(function(value, index, array) {})
* map方法中的回调函数中的3个参数值,每个值value,索引值index,数组对象array
* 上面的相当于parseInt('1', 0)、parseInt('2', 1)、parseInt('3', 2)
* */
} /* Number强转 */
num = Number('12345');
console.log(num);
}

正在努力学习中,若对你的学习有帮助,留下你的印记呗(点个赞咯^_^)

原文地址:https://segmentfault.com/a/1190000017176274

较常用的Math方法及ES6中的扩展的更多相关文章

  1. ES6中字符串扩展

    ES6中字符串扩展 ① for...of 遍历字符串: 例如: for(let codePoint of 'string'){ console.log(codePoint) } 运行结果: ②  in ...

  2. js中常用的Math方法总结

    1.min()和max()方法 Math.min()用于确定一组数值中的最小值.Math.max()用于确定一组数值中的最大值. alert(Math.min(2,4,3,6,3,8,0,1,3)); ...

  3. JS中常用的Math方法

    1.min()和max()方法 Math.min()用于确定一组数值中的最小值.Math.max()用于确定一组数值中的最大值. alert(Math.min(2,4,3,6,3,8,0,1,3)); ...

  4. ES6中数组和对象的扩展运算符拷贝问题以及常用的深浅拷贝方法

    在ES6中新增了扩展运算符可以对数组和对象进行操作.有时候会遇到数组和对象的拷贝,可能会用到扩展运算符.那么这个扩展运算符到底是深拷贝还是浅拷贝呢? 一..使用扩展运算符拷贝 首先是下面的代码. le ...

  5. (转)在网页中JS函数自动执行常用三种方法

    原文:http://blog.sina.com.cn/s/blog_6f6b4c3c0100nxx8.html 在网页中JS函数自动执行常用三种方法 在网页中JS函数自动执行常用三种方法 在HTML中 ...

  6. 160803、如何在ES6中管理类的私有数据

    如何在ES6中管理类的私有数据?本文为你介绍四种方法: 在类的构造函数作用域中处理私有数据成员 遵照命名约定(例如前置下划线)标记私有属性 将私有数据保存在WeakMap中 使用Symbol作为私有属 ...

  7. ES6中的数组

    数组是js中很重要的数据类型,虽然在 ES5 中,关于数组的方法和属性很多.但为了更加简洁.高效的操作数组,ES6 中又在数组原型上和实例上新增了一些方法. 一.Array方法 1.1 Array.f ...

  8. es6对象的扩展

    对象(object)是 JavaScript 最重要的数据结构之一. object 在es6中新增了很多便利的方法 在es6中允许直接写入变量和方法的名称直接作为对象的属性 let x =1 ,y=2 ...

  9. ES6数组的扩展--Array.from()和Array.of()

    一. Array.from() : 将伪数组对象或可遍历对象转换为真数组 1.何为伪数组 如果一个对象的所有键名都是正整数或零,并且有length属性,那么这个对象就很像数组,语法上称为"类 ...

随机推荐

  1. 面试题思考:Java 8 / Java 7 为我们提供了什么新功能

    Java 7 的7个新特性 1.对集合类的语言支持: 2.自动资源管理: 3.改进的通用实例创建类型推断: 4.数字字面量下划线支持: 5.switch中使用string: 6.二进制字面量: 7.简 ...

  2. 《从零开始学Swift》学习笔记(Day 57)——Swift编码规范之注释规范:文件注释、文档注释、代码注释、使用地标注释

    原创文章,欢迎转载.转载请注明:关东升的博客 前面说到Swift注释的语法有两种:单行注释(//)和多行注释(/*...*/).这里来介绍一下他们的使用规范. 1.文件注释 文件注释就在每一个文件开头 ...

  3. Fluent Ribbon 第六步 StartScreen

    上一节,介绍了Toolbar的主要功能,说明了ToolBar的一些最基本用法,这一节,介绍Ribbon的一个重要功能startScreen, startScreen软件第一次启动,呈现的界面. 由于R ...

  4. delphi xe-intarweb 功能记录

    IWServerController.HistoryEnabled := True; //使浏览器后退.前进按钮有效TIWForm2.Create(WebApplication).Show;  //建 ...

  5. pre 布局

    w

  6. Andrew Ng机器学习编程作业:Multi-class Classification and Neural Networks

    作业文件 machine-learning-ex3 1. 多类分类(Multi-class Classification) 在这一部分练习,我们将会使用逻辑回归和神经网络两种方法来识别手写体数字0到9 ...

  7. 开发微信公众平台--新建新浪云sae部署server

    创建新浪云计算应用 申请账号 我们使用SAE新浪云计算平台作为server资源.而且申请PHP环境+MySQL数据库作为程序执行环境. 申请地址:百度搜sae ,使用新浪微博账号能够直接登录SAE,登 ...

  8. 【Myeclipse设置】MyEclipse取消Show in Breadcrumb的方法

    有时不小心把快捷导航整出来,对于本来就很小的编辑空间来讲就很痛苦了,下面的方法可行,本人亲自试验过. 参考地址:百度文库中的解决方法 在最后用户通过点击出来的图标 ,就可以自如的控制出现和消失了.

  9. SIP穿越NAT SIP穿越防火墙-SBC

    FireWall&NAT FireWall是一种被动网络安全防卫技术,位于网络的边界.在两个网络之间运行訪问控制策略.防止外部网络对内部信息资源的非法訪问,也能够阻止特定信息从内部网络被非法输 ...

  10. nginx规则总结

    location正则写法 一个示例: location = / { # 精确匹配 / ,主机名后面不能带任何字符串 [ configuration A ] } location / { # 因为所有的 ...