较常用的Math方法及ES6中的扩展
记录下与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中的扩展的更多相关文章
- ES6中字符串扩展
ES6中字符串扩展 ① for...of 遍历字符串: 例如: for(let codePoint of 'string'){ console.log(codePoint) } 运行结果: ② in ...
- js中常用的Math方法总结
1.min()和max()方法 Math.min()用于确定一组数值中的最小值.Math.max()用于确定一组数值中的最大值. alert(Math.min(2,4,3,6,3,8,0,1,3)); ...
- JS中常用的Math方法
1.min()和max()方法 Math.min()用于确定一组数值中的最小值.Math.max()用于确定一组数值中的最大值. alert(Math.min(2,4,3,6,3,8,0,1,3)); ...
- ES6中数组和对象的扩展运算符拷贝问题以及常用的深浅拷贝方法
在ES6中新增了扩展运算符可以对数组和对象进行操作.有时候会遇到数组和对象的拷贝,可能会用到扩展运算符.那么这个扩展运算符到底是深拷贝还是浅拷贝呢? 一..使用扩展运算符拷贝 首先是下面的代码. le ...
- (转)在网页中JS函数自动执行常用三种方法
原文:http://blog.sina.com.cn/s/blog_6f6b4c3c0100nxx8.html 在网页中JS函数自动执行常用三种方法 在网页中JS函数自动执行常用三种方法 在HTML中 ...
- 160803、如何在ES6中管理类的私有数据
如何在ES6中管理类的私有数据?本文为你介绍四种方法: 在类的构造函数作用域中处理私有数据成员 遵照命名约定(例如前置下划线)标记私有属性 将私有数据保存在WeakMap中 使用Symbol作为私有属 ...
- ES6中的数组
数组是js中很重要的数据类型,虽然在 ES5 中,关于数组的方法和属性很多.但为了更加简洁.高效的操作数组,ES6 中又在数组原型上和实例上新增了一些方法. 一.Array方法 1.1 Array.f ...
- es6对象的扩展
对象(object)是 JavaScript 最重要的数据结构之一. object 在es6中新增了很多便利的方法 在es6中允许直接写入变量和方法的名称直接作为对象的属性 let x =1 ,y=2 ...
- ES6数组的扩展--Array.from()和Array.of()
一. Array.from() : 将伪数组对象或可遍历对象转换为真数组 1.何为伪数组 如果一个对象的所有键名都是正整数或零,并且有length属性,那么这个对象就很像数组,语法上称为"类 ...
随机推荐
- 【Raspberry Pi】webpy+mysql+GPIO 实现手机控制
1.mysql http://dev.mysql.com/doc/refman/5.5/en/index.html 安装 sudo apt-get install update sudo apt-ge ...
- SurvivalShooter学习笔记(二.玩家移动旋转)
该案例中:(PC端操作) 1.玩家移动输入控制通过虚拟轴Axis,旋转输入控制通过鼠标位置: 2.玩家始终面朝鼠标停留点,鼠标停留点通过摄像机朝地面的射线获取: 3.玩家待机移动状态切换通过Anima ...
- 搭建一个SSM框架
刚好学完springMVC,mybatis简单的组合,总结一下 1.创建一个maven项目,引入jar包 一共这么多,除了oracle jar包是我手动添加到lib里,其他都是通过pom.xml引入的 ...
- Linux中buffer/cache,swap,虚拟内存和page ++
1.Buffer 和 cache Free 命令相对于top 提供了更简洁的查看系统内存使用情况: [apptest@vs022 ~]$ free -m ——以MB为单位 ...
- 把資源加载到内存中 BMP 出错
BMP文件放到VS的資源中時,VS會將BMP的文件頭去掉,即BITMAPFILEHEADER,這個結構體去除.所以當加載BMP到內存中時,如果是使用GDI+或是其它解釋庫時,會解析失敗. 所以在讀取B ...
- 基础知识《三》java修饰符
一.修饰符 private 成员随时都是“私有”的,任何人不得访问.但在实际应用中,经常想把某些东西深深地藏起来,但同时允许访问衍生类的成员. protected 关键字可帮助我们做到这一点.它的意思 ...
- 服务器证书日期无效 SSL_DATE_INVALID
一大早上,企业微信中提示不能使用:服务器证书日期无效 错误码:SSL_DATE_INVALID 网上资料也比较少,咨询了一下企业微信客服,建议访问网址:https://www.ssllabs.com ...
- delphi --批量添加
公共批量添加方法 function BatchSQL(DC : TADOConnection; Qry : TADOQuery; StrSQL : TStrings): Boolean; var i ...
- 并发编程8 线程的创建&验证线程之间数据共享&守护线程&线程进程效率对比&锁(死锁/递归锁)
1.线程理论以及线程的两种创建方法 2.线程之间是数据共享的与join方法 3.多线程和多进程的效率对比 4.数据共享的补充线程开启太快 5.线程锁 互斥锁 同步锁 6.死锁现象和递归锁 7.守护线程 ...
- 直播未来属于RTMP还是HTTP
直播未来属于RTMP还是HTTP? - Tinywan - 博客园 https://www.cnblogs.com/tinywan/p/6122065.html 直播未来属于RTMP还是HTTP? H ...