记录下与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. Deep Learning阅读资料

    入门基础阅读:http://www.cnblogs.com/avril/archive/2013/02/08/2909344.html 书籍推荐:http://blog.chinaunix.net/u ...

  2. asscert断言的几种方法

    一.什么是断言 执行完测试用例后,最后一步是判断测试结果是通过还是失败,在自动化脚本中一般把这种生成测试结果的方法叫做断言 它用来检查一个条件,如果它为真,则不做任何事,如果它为假,则会跑出Asser ...

  3. ASP.NET Web API 2中的属性路由(Attribute Routing)

    如何启用属性路由并描述属性路由的各种选项? Why Attribute Routing? Web API的第一个版本使用基于约定的路由.在这种类型的路由中,您可以定义一个或多个路由模板,这些模板基本上 ...

  4. 如何下载ubuntu桌面,并使用

    下载ubuntu,进行linux系统的操作 1.下载ubuntu 百度搜索ubuntu或直达下载链接http://cn.ubuntu.com/download/ 你可以选择,优麒麟16或者Ubuntu ...

  5. 根据百度地图API得到坐标和地址并在地图上显示

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout ...

  6. centos7上修改运行级别

    查看运行级别的原配置文件,和centos6上明显的不同: 运行级别控制文件: [root@nginx1 python]# ll /etc/systemd/system/default.targetlr ...

  7. 【BZOJ2194】快速傅立叶之二

    [BZOJ2194]快速傅立叶之二 Description 请计算C[k]=sigma(a[i]*b[i-k]) 其中 k < = i < n ,并且有 n < = 10 ^ 5. ...

  8. Android 中 js 和 原生交互

    Android中的WebView 中加载的URL 默认是在手机浏览器中加载的,我们可以覆盖这种默认的动作,让网页在WebView中打开.通过设置WebView的WebViewClent 达到这个效果. ...

  9. JavaScript表示x的y次幂

    一.指数运算符(**) 示例 console.log(2 ** 2); // 4 console.log(3 ** 2); // 9 console.log('3' ** '2'); // 9 con ...

  10. HTTP 协议介绍

    HTTP 协议规定了浏览器和服务器之间互相通信的规则. 请求协议: 规定了客户端发送给服务器的内容格式 响应协议: 服务器发送给客户端的内容格式 请求协议 请求协议格式: 请求行 多个请求头信息(属性 ...