JavaScript里处理数字的一些常用方法
1.toString() 把字符串转换为数值。
let num = 123;
console.log(typeof(num)); //number
console.log(typeof(num.toString())) //string
- typeof() 判断数据类型
2.toLocaleString() 方法可把一个 Number 对象转换为本地格式的字符串。
LocaleString()会根据你机器的本地环境来返回字符串,它和toString()返回的值在不同的本地环境下使用的符号可能变化;
var a = 6666;
a.toLocaleString();
// "6,666"
a.toString();
//"6666"
var dt = new Date();
console.log(dt.toLocaleString());
//2019/9/11 下午4:46:04
console.log(dt.toString());
//Wed Sep 11 2019 16:46:04 GMT+0800
3.toFixed() 返回字符串值,它包含了指定位数小数的数字。
let num1 = 3.1415;
console.log(num1.toFixed(0)); //
console.log(num1.toFixed(1)); // 3.1
console.log(num1.toFixed(2)); // 3.14
console.log(num1.toFixed(5)); // 3.14150
- toFixed(2) 非常适合处理金钱。
4.Number() 可用于把 JavaScript 变量转换为数值。
Number(true); //
Number(false); //0
let x = new Date();
console.log(Number(x)); // 1568186258917 时间戳 Number() 方法返回 1970 年 1 月 1 日至今的毫秒数
console.log(Number(new Date("2019-09-11"))); // 1568186258917 时间戳 Number() 还可以把日期转换为数字: Number('12'); // 12 数字类型
Number(11 22); // NaN
Number(undefined); //NaN
特殊情况 因为空字符串、null 和0都是false
Number(null) ;//0;
Number(''); //0;
5.parseInt() 解析一段字符串,并返回一个整数。(取整)
parseInt("10"); // 返回 10
parseInt("10.33"); // 返回 10
parseInt("10 20 30"); // 返回 10
parseInt("10 years"); // 返回 10
parseInt("years 10"); // 返回 NaN 如果无法转换为数值,则返回 NaN (Not a Number)
6.parseFloat()解析一个字符串,并返回一个浮点数。
- parseFloat() 解析一段字符串并返回数值。允许空格。只返回首个数字
- 如果无法转换为数值,则返回 NaN (Not a Numbe)
parseFloat("10"); // 返回 10
parseFloat("10.33"); // 返回 10.33
parseFloat("10 20 30"); // 返回 10
parseFloat("10 years"); // 返回 10
parseFloat("years 10"); // 返回 NaN
7. Math.min() 方法可返回两个指定的数中带有较小的值的那个数。
Math.min(5,'7'); //
Math.min(5,'q'); //NaN 如果有某个参数为 NaN,或是不能转换成数字的非数字值,则返回 NaN
8. Math.max() 方法可返回两个指定的数中带有较大的值的那个数。
Math.max(5,'7'); //
Math.max(5,'q'); //NaN 如果有某个参数为 NaN,或是不能转换成数字的非数字值,则返回 NaN
9.Math.abs() 方法可返回数的绝对值
Math.abs(-7.25); // 7.25
10.Math.ceil() 方法可对一个数进行上舍入
- ceil() 方法执行的是向上取整计算,它返回的是大于或等于函数参数,并且与之最接近的整数。
Math.ceil(0.60); //
Math.ceil(0.40); //
Math.ceil(-5.1); //
11.Math.floo() 方法可对一个数进行下舍入
Math.floor(0.60); //
Math.floor(0.40); //
Math.floor(-5.1); //-6
12.Number.isInteger() 用于判断其参数是为整数
Number.isInteger(0); // true
Number.isInteger(0.1); // false
13.Number.parseFloat()和parseFloat()一样。
14.Number.parseInt()和parseInt()一样。
15.isNaN() 函数用于检查其参数是否是非数字值(和Number.isNaN()一样)
无法使用 for/in 循环来枚举 NaN 属性,也不能用 delete 运算符来删除它。
使用 isNaN() 来判断一个值是否是数字。原因是 NaN 与所有值都不相等,包括它自己。
false的话 就是数字或者隐形数字类型
isNaN(123); // false
isNaN('123'); //false
isNaN('cao'); //true
isNaN('NaN');//true
es6新增
16.Math.trunc方法用于去除一个数的小数部分,返回整数部分。
Math.trunc(4.1) //
Math.trunc(4.9) //
Math.trunc(-4.1) // -4
Math.trunc(-4.9) // -4
Math.trunc(NaN); // NaN
Math.trunc('foo'); // NaN
Math.trunc(); // NaN
17.Math.sign方法用来判断一个数到底是正数、负数、还是零参数为正数,返回+1;
- 参数为负数,返回-1;
- 参数为正数,返回+1;
- 参数为0,返回0;
- 参数为-0,返回-0;
- 其他值,返回NaN。
Math.sign(-5) // -1
Math.sign(5) // +1
Math.sign(0) // +0
Math.sign(-0) // -0
Math.sign(NaN) // NaN
Math.sign('foo'); // NaN
Math.sign(); // NaN
JavaScript里处理数字的一些常用方法的更多相关文章
- JavaScript里处理数组的一些常用方法
修改器方法: 1.pop() 方法从数组中删除最后一个元素 pop() 方法将删除 arrayObject 的最后一个元素,把数组长度减 1,并且返回它删除的元素的值. let arr2 = ['zh ...
- JavaScript里处理字符串的一些常用方法
1.length 属性返回字符串的长度 let srt = "hello world!"; console.log(srt.length) // 12 2.indexOf() 方法 ...
- JavaScript 中的数字和日期类型
本章节介绍如何掌握Javascript里的数字和日期类型 数字EDIT 在 JavaScript 里面,数字都是双精度浮点类型的 double-precision 64-bit binary form ...
- Javascript里,想把一个整数转换成字符串,字符串长度为2
Javascript里,想把一个整数转换成字符串,字符串长度为2. 想把一个整数转换成字符串,字符串长度为2,怎么弄?比如 1 => "01"11 => " ...
- JavaScript 里,$ 代表什么?/JQuery是什么语言?/html中用link标签引入css时的中 rel="stylesheet"属性?/EL表达式是什么?
JavaScript 里,$ 代表什么? 比如说我写一个mouseover事件: $(document).ready(function(){ $("p").mouseover(fu ...
- javascript里的偏函数——本质函数式编程+闭包,返回函数
最终效果: var greet = function(greeting, name) { return greeting + ' ' + name; }; var sayHelloTo = _.par ...
- JavaScript里值比较的方法
JavaScript里值比较的方法 参考资料 一张图彻底搞懂JavaScript的==运算 toString()和valueof()方法的区别 Object.is 和 == 与 === 不同 == 运 ...
- JavaScript 里的 'this' 的一般解释
本文旨在帮助自己和大家理解 JS 里的 this, 翻译.整理并改写自本人关注的一个博主 Dmitri Pavlutin,原文链接如下: https://dmitripavlutin.com/gent ...
- javascript里for循环的一些事情
今天在给一个学妹调她的代码BUG时,她的问题就是在一个for循环里不清楚流程的具体流向,所以导致了页面怎么调都是有问题,嗯确实你如果不清楚语句流向很轻易就会出问题,所以说for循环不会用或者说用的不恰 ...
随机推荐
- 前端笔记之React(八)上传&图片裁切
一.上传 formidable天生可以处理上传的文件,非常简单就能持久上传的文件. 今天主要讲解的是,前后端的配合套路. 上传分为同步.异步.同步公司使用非常多,异步我们也会讲解. 1.1 先看一下a ...
- 简洁明了的Noip考场策略 / 平时做题也适用
1.选择策略: 评估的标准得分的难度不是AC的难度 2.思考问题: 怀疑的眼光审视自己 3.写代码前: 想想可不可以换一种代码实现会好写很多 把自己的思路再理一遍,可以写到纸上,记下来大致关键顺序 4 ...
- Computing Jobs
docker&k8shadoopsparkhbasemesosrediskafkazookeeper SCSI.NVMe.PCIe devops
- Opengl_入门学习分享和记录_02_渲染管线(一)顶点输入
现在前面的废话:最近好事不断!十分开心!生活真美好! 好了今天要梳理一下,顶点输入的具体过程,同样也是渲染管线中的第一个阶段的详细过程的介绍.之前介绍过,OpenGL操作的是一组3D坐标,所以我们的输 ...
- dart的基本语法(一)
Hello world 安装dart的环境就不赘述了,无脑安装就可以了,安装过程中好像需要梯子(vpn),我装的时候失败好多次,我的梯子不能用了,准备不装了的时候,莫名其妙的装好了.迷の操作.惯例 ...
- 100天搞定机器学习|Day 30-32 微积分的本质
3blue1brown系列课程,精美的动画,配上生动的讲解,非常适合帮助建立数学的形象思维,非常值得反复观看: http://www.3blue1brown.com/ 哔哩哔哩: https://sp ...
- 安全测试基础2-sqlmap演练
sqlmap简介 sqlmap是一个开源的渗透测试工具,可以用来进行自动化检测,利用SQL注入漏洞,获取数据库服务器的权限. 它具有功能强大的检测引擎,针对各种不同类型数据库的渗透测试的功能选项,包括 ...
- vim 基础配置
最近在使用 python 搞服务, 简单配置了一个 vim, 配置了自动补全以及背景色 .(ps:搜狗输入法快捷键占用真是太坑爹,改用谷歌输入法,世界安静了) 具体配置如下: 一. 安装插件 1.克隆 ...
- Mybatis中使用PageHelper插件进行分页
分页的场景比较常见,下面主要介绍一下使用PageHelper插件进行分页操作: 一.概述: PageHelper支持对mybatis进行分页操作,项目在github地址: https://github ...
- nodeCZBK-笔记2
目录 day04 mongoDB数据库使用 day05 node使用mongoDB数据库 day04 mongoDB数据库使用 电脑全局安装数据库 开机命令:mongod --dbpath c:\mo ...