JS数据类型(七种基础,三种引用)

JavaScript012

JS数据类型(七种基础,三种引用),第1张

在JS的学习与工作中,搞清楚相关数据类型是基础中的基础,平均一百家公司面试前端工程师的时候九十九家都会问,请你简单举例一下JS的数据类型,于是菜狗我就将对此进行一些自己粗浅的总结为自己留作笔记同时为各位想要学习的同学提供小小的帮助。

首先,我们要明白,在JS中,数据类型分为一下两种:

基础数据类型分为七种

①Number 数字型 (包含所有的整数,浮点数,负数等)

②String 字符串型 (包含任意文本)

③boolean 布尔型 (仅有两种类型,ture与false)

④Undefined 未定义 (仅有一种,undefined)

⑤Null 空/不存在 (仅有一种,null)

⑥Symbol (实现唯一标识)

对此进行简单的举例

⑦BigInt(任意精度整数)(将与ES10中出现)

对此数据类型存在进行简单解释

BigInt 通过数字加n的方法来表示,支持二进制,八进制,十六进制

以下写法结果均为转换为字符串后得而结果,BigInt类型转换字符串后不会再带着n

Ⅰ.通常写法

Ⅱ .十六进制

Ⅲ.八进制(注意区分数字0与字母o)

Ⅳ. 二进制

引用数据类型共有三种

①Array类型 (数组型)

②Object类型 (对象型)

③Function类型 (函数/方法)

以上就是十种JS中的数据类型,如有错误,欢迎指正。

如果本文能帮到你,那么菜狗很开心,大家一起 加油!

JavaScript中的运算符优先级是一套规则。该规则在计算表达式时控制运算符执行的顺序。具有较高优先级的运算符先于较低优先级的运算符执行。例如,乘法的执行先于加法。

算数运算符:

加+,减—,乘*,除/,求余%,加加++,减减——,

加减乘除求余运算与数学上的用法完全一样。

不过,加号+还有连接字符串的作用,其他运算符还可以将字符串数字转换成数值型,参见 JavaScript中数据类型转换总结 中的隐式转换部分。

++,——分为前置和后置,前置表示在使用该变量之前加/减1,后置表示在使用之后加/减1。

逻辑运算符:

1.&&: 与运算, 当与运算的两个内容都为true的时候,结果为true,只要有一个内容为false,结果都是false,&&可以读作“并且”

2.||: 或运算, 当或运算的两个内容都为false的时候,结果为false,只要有一个内容为true,结果都是true,|| 可以读作“或者”

3.!:非运算, 取反运算,当内容为true时,取反结果为false,当内容为false时,取反结果为true

补充:

&&与||的其他用法

&&

如果两个操作数都不是布尔类型

且两个数值转换成布尔类型都是true,返回第二个操作数

如果有一个操作数转换成布尔类型是false,返回这个数

var b=undefined&&null

console.log(b)

返回undefined

||

如果两个操作数都不是布尔类型

第一个数转换成布尔类型为true,则不往下看,返回第一个数

如果第二个数转换成布尔类型为true,则返回第二个数值。

比较运算符:

== 相等操作符

如果两个操作数相等,则返回 true。

!= 不相等操作符

如果两个操作数不相等,则返回 true。

这两个操作符都会先转换操作数(通常称为强制转型),然后再比较它们的相等性。在转换不同的数据类型时,相等和不相等操作符遵循下列基本规则:

1、 如果有一个操作数是布尔值,则在比较相等性之前先将其转换为数值——false 转换为 0,而true 转换为 1;

2、如果一个操作数是字符串,另一个操作数是数值,在比较相等性之前先将字符串转换为数值;

3、 如果一个操作数是对象,另一个操作数不是,则调用对象的 valueOf()方法,用得到的基本类型值按照前面的规则进行比较;

这两个操作符在进行比较时则要遵循下列规则。

1、 null 和 undefined 是相等的。

2、 要比较相等性之前,不能将 null 和 undefined 转换成其他任何值。

3、 如果有一个操作数是 NaN,则相等操作符返回 false,而不相等操作符返回 true。重要提示:

即使两个操作数都是 NaN,相等操作符也返回 false;因为按照规则, NaN 不等于 NaN。

如果两个操作数都是对象,则比较它们是不是同一个对象。如果两个操作数都指向同一个对象,

则相等操作符返回 true;否则,返回 false。

下表列出了一些特殊情况及比较结果:

=== 全等操作符

在两个操作数未经转换就相等的情况下返回 true。即数值和类型都相同。

var result1 = ("55" == 55)//true,因为转换后相等

var result2 = ("55" === 55)//false,因为不同的数据类型不相等

!== 不全等操作符

在两个操作数未经转换就不相等的情况下返回 true。数据类型不同就不等。

var result1 = ("55" != 55)//false,因为转换后相等

var result2 = ("55" !== 55)//true,因为不同的数据类型不相等

赋值运算符:

=,+=,-=,*=,/=

简单的赋值操作符由等于号(=)表示,其作用就是把右侧的值赋给左侧的变量。

如果在等于号(=)前面再添加乘性操作符、加性操作符或位操作符,就可以完成复合赋值操作。

num = num + 10等同于num += 10

设计这些操作符的主要目的就是简化赋值操作。使用它们不会带来任何性能的提升。

三元运算符:

? :

举个例子:

var max = (num1 >num2) ? num1 : num2

在这个例子中, max 中将会保存一个最大的值。这个表达式的意思是:如果 num1 大于 num2(关系表达式返回 true),则将 num1 的值赋给 max;如果 num1 小于或等于 num2(关系表达式返回 false),则将 num2 的值赋给 max。

位运算符:

JavaScript也有位运算符,需要先转换成16进制数进行运算,在开发中好像还没有用到过,了解一下即可。

javascript 中运算符优先级

将float类型转化为int类型有两种方法:

1、在计算时,可以使用向上取整Math.ceil(50/4),或者向下取整math.floor(50/4),或者四舍五入Math.round(50/4)

2、直接使用强制转化为整数的方法parseInt,parseInt(50/4)

1)parseInt 函数将其第一个参数转换为字符串,解析它,并返回一个整数或NaN。如果不是NaN,返回的值将是作为指定基数(基数)中的数字的第一个参数的整数。

2)parseInt有两个参数,第一个是需要转化的内容,第二个是需要转化的进制数,默认为十进制。也可以转化为八进制、十六进制、二进制。如下:

3)parseInt也可以将首部有”数字的字符串“转化为数字,例如:parseInt('12.0swrf')//返回:12

4)另外,还有一个与parseInt用法和作用类似的方法parseFloat(string,radix),parseFloat是将字符串或者数字,强制转化为浮点数类型。

扩展资料:

1、javascript是弱语言类型,定义变量时没有区分字符串,整数,浮点数。但是它很灵活,可以进行不同类型的转换。

2、javascript基本数据类型有以下几种:Number,String,Boolean,Undefined,Null,Symbol,可以根据Number,String,Boolean,Symbol这几种类型内置对象,将变量强制转换为对应的类型。如下:

参考资料:

MDN技术文档-parseInt 语法

MDN技术文档-js的数据类型和数据结构