JavaScript 数字类型

目前有两种类型:

  1. number
  2. BigInt 是表示任意长度的整数

数字的三个特殊值

  1. Infinity

    属性用于存放表示正无穷大的数值。
  2. -Infinity

    属性用于存放表示负无穷大的数值。
  3. NaN

    属性用于引用特殊的非数字值。

e可以代替任意零

  • 正数:
//用法
1e3 = 1 * 1000
1.23e6 = 1.23 * 1000000
  • 负数
//用法
let ms = 1e-6; // 1 的左边有 6 个 0

十六进制,二进制和八进制数字

格式:

  • 十六进制:0x数字
  • 八进制进制:0b数字
  • 二进制进制:0o数字

十六进制书不分大小写

数字方法及属性:

JavaScript 有一个内建的 Math 对象,它包含了一个小型的数学函数和常量库。

toString()

//用法
let num = 255;
num.toString(16); // ff
num.toString(2); // 11111111

floor() ceil() round() trunc()

  1. 数字.floor

    向下舍入:3.1 变成 3,-1.1 变成 -2。
  2. 数字.ceil

    向上舍入:3.1 变成 4,-1.1 变成 -1。
  3. 数字.round

    向最近的整数舍入:3.1 变成 3,3.6 变成 4,-1.1 变成 -1。
  4. 数字.trunc(IE 浏览器不支持这个方法)

    移除小数点后的所有内容而没有舍入:3.1 变成 3,-1.1 变成 -1。
//用法
Math.floor(value)
Math.ceil(value)
Math.round(value)
Math.trunc(value)

这个是总结它们之间差异的表格:

Math.floor Math.ceil Math.round Math.trunc
3.1 3.1 3.1 3.1
3.1 3 4 3 3
3.6 3 4 4 3
-1.1 -2 -1 -1 -1
-1.6 -2 -1 -2 -1

toFixed()

方法可把 Number 四舍五入为指定小数位数的数字。

//用法
let num = 1.1111;
num.toFixed(1)

注意 : 返回的是一个字符

isNaN() 与 isFinite()

  1. isNaN(value)

    将其参数转换为数字,然后测试它是否为 NaN:
  2. isFinite(value)

    将其参数转换为数字,如果是常规数字,则返回 true,而不是 NaN/Infinity/-Infinity:
//用法
isNaN(NaN);// true
isNaN("str");// true
isFinite(1); // true
isFinite("str"); // false,因为是一个特殊的值:NaN
isFinite(Infinity); // false,因为是一个特殊的值:Infinity

注意,在所有数字函数中,包括 isFinite,空字符串或仅有空格的字符串均被视为 0。

parseInt() 与 parseFloat()

从字符串中“读取”数字,直到无法读取为止。如果发生 error,则返回收集到的数字。

函数 parseInt 返回一个整数,

函数 parseFloat 返回一个浮点数:

parseInt(string, radix); 可以传两个参数

第一个参数为数字(必填),第二个参数为表示要解析的数字的基数(选填)。该值介于 2 ~ 36 之间。

//用法
parseInt('10px'); // 10
parseFloat('1.2em'); // 1.2 parseInt('44.4'); // 44,只返回整数部分
parseFloat('1.2.3.4'); // 1.2,在第二个点出停止了读取 parseInt('a1'); // NaN,第一个符号停止了读取 parseInt("1f",16);// 31

注意:如果字符串的第一个字符不能被转换为数字,那么parseInt() 与 parseFloat() 会返回 NaN。

其他数学函数

random()

返回一个从 0 到 1 的随机数(不包括 1)

//用法
Math.random();
Math.max() 与 Math.min()

从任意数量的参数中返回最大/最小值

//用法
Math.max(1, 3, 5, -1); // 5
Math.min(1, 4, 6 ,7 ); // 1
Math.pow()

返回 参数一 的给定 参数二 次幂

Math.pow()必须有两个参数,第一个参数是 底数 (必须是数字) 第二个参数是 幂数 (必须是数字)

//用法
Math.pow(2, 3); // 2**3=8

总结

Math 对象用于执行数学任务。

使用 Math 的属性和方法的语法:

//用法
var pi_value=Math.PI;
var sqrt_value=Math.sqrt(15);

注意:Math 对象并不像 Date 和 String 那样是对象的类,因此没有构造函数 Math(),像 Math.sin() 这样的函数只是函数,不是某个对象的方法。您无需创建它,通过把 Math 作为对象使用就可以调用其所有属性和方法。

属性 描述
E 返回算术常量 e,即自然对数的底数(约等于2.718)。
LN2 返回 2 的自然对数(约等于0.693)。
LN10 返回 10 的自然对数(约等于2.302)。
LOG2E 返回以 2 为底的 e 的对数(约等于 1.414)。
LOG10E 返回以 10 为底的 e 的对数(约等于0.434)。
PI 返回圆周率(约等于3.14159)。
SQRT1_2 返回返回 2 的平方根的倒数(约等于 0.707)。
SQRT2 返回 2 的平方根(约等于 1.414)。
方法 描述
abs(x) 返回数的绝对值。
acos(x) 返回数的反余弦值。
asin(x) 返回数的反正弦值。
atan(x) 以介于 -PI/2 与 PI/2 弧度之间的数值来返回 x 的反正切值。
atan2(y,x) 返回从 x 轴到点 (x,y) 的角度(介于 -PI/2 与 PI/2 弧度之间)。
ceil(x) 对数进行上舍入。
cos(x) 返回数的余弦。
exp(x) 返回 e 的指数。
floor(x) 对数进行下舍入。
log(x) 返回数的自然对数(底为e)。
max(x,y) 返回 x 和 y 中的最高值。
min(x,y) 返回 x 和 y 中的最低值。
pow(x,y) 返回 x 的 y 次幂。
random() 返回 0 ~ 1 之间的随机数。
round(x) 把数四舍五入为最接近的整数。
sin(x) 返回数的正弦。
sqrt(x) 返回数的平方根。
tan(x) 返回角的正切。
toSource() 返回该对象的源代码。
valueOf() 返回 Math 对象的原始值。

本文参考:

https://www.w3school.com.cn/

https://javascript.info/

JavaScript基础 数字类型的更多相关文章

  1. python基础-数字类型及内置方法

    --数字类型及内置方法 整型-int 用途:多用于年龄.电话.QQ号等变量 定义方法 age = 18 # age = int(18) 常用方式:多用于数学计算 # int(x)将x转换成整数,是向下 ...

  2. EasyUI datagird 排序 按数字类型的问题

    easyui datagird 默认显示的数据都是字符, 对要数字列进行排序规则,需要自定义排序规则如果按字符排序 27竟然小于4 这不是我们想要的.解决方案 <table id='grid'c ...

  3. 【你不知道的javaScript 中卷 笔记1】javaScript中的类型与值

    一.类型与值 1.0 javaScript 七种内置类型: 空值(null) 未定义(undefined) 布尔值( boolean) 数字(number) 字符串(string) 对象(object ...

  4. JavaScript基础系列(变量与类型)

    以下内容将JavaScript简称为JS 打开本文时不管你是零基础的初学者还是其他语言的老兵,我都想说程序语言的基础支撑起了整个网络世界,不把这些基础学透之后稍复杂的内容会让你寸步难行. 现在先给编程 ...

  5. 你真的懂JavaScript基础类型吗

    夯实Javascript基础. 基本类型有六种: null,undefined,boolean,number,string,symbol. 基本类型的值是保存在栈内存中的简单数据段 基础类型特性 基础 ...

  6. JavaScript基础回顾一(类型、值和变量)

    请看代码并思考输出结果 var scope = 'global'; function f(){ console.log(scope); var scope = 'local'; console.log ...

  7. 前端知识体系:JavaScript基础-变量和类型

    前端工程师自检清单 1. JavaScript规定了几种语言类型 2. JavaScript对象的底层数据结构是什么 3. Symbol类型在实际开发中的应用.可手动实现一个简单的 Symbo 4. ...

  8. JavaScript 基础类型,数据类型

    1.基础类型:undefined,null,Boolean,Number,String,Symbol Undefined类型:一个没有被赋值的变量会有个默认值undefined; Null类型:nul ...

  9. javaScript中Number数字类型方法入门

    前言 Number和Math都属于JavaScript中的内置对象,Number数字类型作为基础数据类型,我们在开发过程中会经常用到,包括数字精度的格式化,还有字符串转换成数字等操作. Number数 ...

随机推荐

  1. 如何让BootStrap栅格之间留出空白间隙呢?

    BootStrap栅格之间留出空隙 BootStrap栅格系统可以把我们的container容器划分为若干等分,如果想要每个部分之间留出一定的空隙,我们很可能首先想到的方法就是用margin外边距来使 ...

  2. 【SpringMVC】获取请求参数

    通过ServletAPI获取 test.html <a th:href="@{/testServletAPI(username='admin',password=123456)}&qu ...

  3. Gogs (Go git server) 使用笔记

    issue: 话题,一个新特性,BUG或其他关注的任何话题,都可创建issure,便于讨论,明确目标. label: 标签,一般用于描述issue的类型,如:bug.feature.enhanceme ...

  4. 从零开始实现简单 RPC 框架 6:网络通信之 Netty

    网络通信的开发,就涉及到一些开发框架:Java NIO.Netty.Mina 等等. 理论上来说,类似于序列化器,可以为其定义一套统一的接口,让不同类型的框架实现,事实上,Dubbo 就是这么干的. ...

  5. java agent简介

    java agent简介 主要就是两种,一种的方法是premain,一种是agentmain.这两种的区别是: premain是在jvm启动的时候类加载到虚拟机之前执行的 agentmain是可以在j ...

  6. Install Docker Engine on CentOS 在CentOS 7 上安装Docker

    Install Docker Engine on CentOS OS Requirements 系统要求 To install Docker Engine,you need a maintained ...

  7. Django项目使用requirements.txt文件

    1.生成requirements.txt pip freeze > requirements.txt 2.使用requirements.txt pip install -r requiremen ...

  8. P1721 [NOI2016] 国王饮水记 题解

    蒟蒻的第一篇黑题题解,求过. 题目链接 题意描述 这道题用简洁的话来说,就是: 给你 \(n\) 个数字,你可以让取其中任意若干个数字,每次操作,都会使所有取的数字变为取的数字的平均数,并且你最多只能 ...

  9. Python常见问题 - python3 requests库提示警告InsecureRequestWarning的问题

    当使用 requests 库发送请求时报了以下警告 D:\python3.6\lib\site-packages\urllib3\connectionpool.py:847: InsecureRequ ...

  10. 7-31 堆栈操作合法性 (20 分) PTA

    7-31 堆栈操作合法性 (20 分)   假设以S和X分别表示入栈和出栈操作.如果根据一个仅由S和X构成的序列,对一个空堆栈进行操作,相应操作均可行(如没有出现删除时栈空)且最后状态也是栈空,则称该 ...