较常用的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属性,那么这个对象就很像数组,语法上称为"类 ...
随机推荐
- 为什么要使用自增ID作为主键
1.从业务上来说 在设计数据库时不需要费尽心思去考虑设置哪个字段为主键.然后是这些字段只是理论上是唯一的,例如使用图书编号为主键,这个图书编号只是理论上来说是唯一的,但实践中可能会出现重复的 情况.所 ...
- C# .net 多线程中集合数据同步
from:http://www.cnblogs.com/GavinCome/archive/2008/04/09/1145250.html C# .net 多线程中集合数据同步(转) 集合类通常不是线 ...
- 笔记:C语言图形基本函数及实例五子棋游戏
初始化图形界面 int gdriver; int gmode; gdriver = DETECT; initgraph(&gdriver,&gmode,"" ); ...
- SQL转换全角和半角函数
SQL转换全角和半角函数 CREATE FUNCTION f_Convert( ), --要转换的字符串 @flag bit --转换标志,0转换成半角,1转换成全角 )) AS BEGIN ),@s ...
- linux 项目自动部署脚本
1.使用maven获取源码部署,并可替换配置文件(金融数据分析平台) #!/bin/bash#设置变量cd /home#停止tomcatecho "开始停止tomcat..." p ...
- 【BZOJ4870】[Shoi2017]组合数问题 动态规划(矩阵乘法)
[BZOJ4870][Shoi2017]组合数问题 Description Input 第一行有四个整数 n, p, k, r,所有整数含义见问题描述. 1 ≤ n ≤ 10^9, 0 ≤ r < ...
- html+css写出类似word目录样式的内容
word目录的格式里这种很常见,要用html+css写出来刚开始还有点懵. 左右两边都是内容撑开宽度,中间内容的宽度也不是确定的,也是随着左右两边的内容动态变化的. 最终解决思路是,给右边内容加上白色 ...
- 160722、Javascript函数节流
最近在做网页的时候有个需求,就是浏览器窗口改变的时候需要改一些页面元素大小,于是乎很自然的想到了window的resize事件,于是乎我是这么写的 <!DOCTYPE html> < ...
- devmapper: Thin Pool has 162394 free data blocks which is less than minimum required 163840 free data blocks
问题: 制作镜像的时候报错 devmapper: Thin Pool has 162394 free data blocks which is less than minimum required 1 ...
- delphi------项目类型
Console Application:控制台应用程序 writeln('HelloWorld'); //接收用户输入字符 readln: //直到用户输入回车结束 VCL Forms Applica ...