JavaScript基础 数字类型
JavaScript 数字类型
目前有两种类型:
- number
- BigInt 是表示任意长度的整数
数字的三个特殊值
- Infinity
属性用于存放表示正无穷大的数值。 - -Infinity
属性用于存放表示负无穷大的数值。 - 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()
- 数字.floor
向下舍入:3.1 变成 3,-1.1 变成 -2。 - 数字.ceil
向上舍入:3.1 变成 4,-1.1 变成 -1。 - 数字.round
向最近的整数舍入:3.1 变成 3,3.6 变成 4,-1.1 变成 -1。 - 数字.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()
- isNaN(value)
将其参数转换为数字,然后测试它是否为 NaN: - 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基础 数字类型的更多相关文章
- python基础-数字类型及内置方法
--数字类型及内置方法 整型-int 用途:多用于年龄.电话.QQ号等变量 定义方法 age = 18 # age = int(18) 常用方式:多用于数学计算 # int(x)将x转换成整数,是向下 ...
- EasyUI datagird 排序 按数字类型的问题
easyui datagird 默认显示的数据都是字符, 对要数字列进行排序规则,需要自定义排序规则如果按字符排序 27竟然小于4 这不是我们想要的.解决方案 <table id='grid'c ...
- 【你不知道的javaScript 中卷 笔记1】javaScript中的类型与值
一.类型与值 1.0 javaScript 七种内置类型: 空值(null) 未定义(undefined) 布尔值( boolean) 数字(number) 字符串(string) 对象(object ...
- JavaScript基础系列(变量与类型)
以下内容将JavaScript简称为JS 打开本文时不管你是零基础的初学者还是其他语言的老兵,我都想说程序语言的基础支撑起了整个网络世界,不把这些基础学透之后稍复杂的内容会让你寸步难行. 现在先给编程 ...
- 你真的懂JavaScript基础类型吗
夯实Javascript基础. 基本类型有六种: null,undefined,boolean,number,string,symbol. 基本类型的值是保存在栈内存中的简单数据段 基础类型特性 基础 ...
- JavaScript基础回顾一(类型、值和变量)
请看代码并思考输出结果 var scope = 'global'; function f(){ console.log(scope); var scope = 'local'; console.log ...
- 前端知识体系:JavaScript基础-变量和类型
前端工程师自检清单 1. JavaScript规定了几种语言类型 2. JavaScript对象的底层数据结构是什么 3. Symbol类型在实际开发中的应用.可手动实现一个简单的 Symbo 4. ...
- JavaScript 基础类型,数据类型
1.基础类型:undefined,null,Boolean,Number,String,Symbol Undefined类型:一个没有被赋值的变量会有个默认值undefined; Null类型:nul ...
- javaScript中Number数字类型方法入门
前言 Number和Math都属于JavaScript中的内置对象,Number数字类型作为基础数据类型,我们在开发过程中会经常用到,包括数字精度的格式化,还有字符串转换成数字等操作. Number数 ...
随机推荐
- 如何让BootStrap栅格之间留出空白间隙呢?
BootStrap栅格之间留出空隙 BootStrap栅格系统可以把我们的container容器划分为若干等分,如果想要每个部分之间留出一定的空隙,我们很可能首先想到的方法就是用margin外边距来使 ...
- 【SpringMVC】获取请求参数
通过ServletAPI获取 test.html <a th:href="@{/testServletAPI(username='admin',password=123456)}&qu ...
- Gogs (Go git server) 使用笔记
issue: 话题,一个新特性,BUG或其他关注的任何话题,都可创建issure,便于讨论,明确目标. label: 标签,一般用于描述issue的类型,如:bug.feature.enhanceme ...
- 从零开始实现简单 RPC 框架 6:网络通信之 Netty
网络通信的开发,就涉及到一些开发框架:Java NIO.Netty.Mina 等等. 理论上来说,类似于序列化器,可以为其定义一套统一的接口,让不同类型的框架实现,事实上,Dubbo 就是这么干的. ...
- java agent简介
java agent简介 主要就是两种,一种的方法是premain,一种是agentmain.这两种的区别是: premain是在jvm启动的时候类加载到虚拟机之前执行的 agentmain是可以在j ...
- Install Docker Engine on CentOS 在CentOS 7 上安装Docker
Install Docker Engine on CentOS OS Requirements 系统要求 To install Docker Engine,you need a maintained ...
- Django项目使用requirements.txt文件
1.生成requirements.txt pip freeze > requirements.txt 2.使用requirements.txt pip install -r requiremen ...
- P1721 [NOI2016] 国王饮水记 题解
蒟蒻的第一篇黑题题解,求过. 题目链接 题意描述 这道题用简洁的话来说,就是: 给你 \(n\) 个数字,你可以让取其中任意若干个数字,每次操作,都会使所有取的数字变为取的数字的平均数,并且你最多只能 ...
- Python常见问题 - python3 requests库提示警告InsecureRequestWarning的问题
当使用 requests 库发送请求时报了以下警告 D:\python3.6\lib\site-packages\urllib3\connectionpool.py:847: InsecureRequ ...
- 7-31 堆栈操作合法性 (20 分) PTA
7-31 堆栈操作合法性 (20 分) 假设以S和X分别表示入栈和出栈操作.如果根据一个仅由S和X构成的序列,对一个空堆栈进行操作,相应操作均可行(如没有出现删除时栈空)且最后状态也是栈空,则称该 ...