JS的基本数据类型
Posted 平凡人的普通修仙之路
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS的基本数据类型相关的知识,希望对你有一定的参考价值。
1.数据类型
数据分为原始类型和引用类型
原始类型分为数值型、字符串型、布尔型、未定义型、空
(1)数值型
分为整型和浮点型
整型在内存中占4个字节,浮点型占8个字节
八进制 以0开头
十六进制 以0X开头,a~f 代表10~15 不区分大小写
0XFF -> 255
浮点型分为定点小数和指数型小数
3140 3.14e3 指数
-0.314 3.14e-1
3.14
typeof 检测数据类型
(2)字符串型
数据被引号所包含就是字符串型,不区分单双引号
查看任意一个字符的Unicode码
‘然‘.charCodeAt() //28982
(3)布尔型
true/false
在程序中表示真或者假
用于一些比较的结果,还有一些是否的结果,例如是否登录,是否注册,是否在售...
(4)未定义型
声明了变量未赋值,结果就是undefined
(5)空——null
只有一个值null,将来会和引用类型一起使用
2.数据类型转换
(1)隐式转换
在运算的过程中,自动的发生转换
1)数字+字符串 数字被转成字符串
2+‘3‘ //‘23‘
2)数字+布尔型 布尔型转成数字 true->1 false->0
3+true //4
3+false //3
3)布尔型+字符串 布尔型转成字符串
‘5‘+true //‘5true‘
JS中加号(+)的作用
执行加法运算
执行字符串间的拼接
减法(-)、乘法(*)、除法(/)隐式转换
将运算符两端的数据转为数值型,如果转换失败,返回NaN(Not a Number),不是一个数字,任何值和NaN执行加减乘除都会返回NaN;自动调用了Number转换成数值型。
练习:查看以下程序的运行结果
var num1=3,num2=true,num3=‘tedu‘;
console.log(num1+num2+num3);//‘4tedu‘
console.log(num2+num3+num1);‘truetedu3‘
console.log(num3+num1+num2);‘tedu3true‘
(2)强制转换
1)强制转为数值型
Number()
Number(‘2‘) //2 Number(true) //1 Number(‘2a‘) //NaN Number(undefined) //NaN Number(null) //0 |
2)强制转换为整型
parseInt()
常用于将字符串或者数字转为整型,其它的数据返回NaN,如果要转换的字符串开头是非数字,则返回NaN
3)强制转为浮点型
parseFloat()
和parseInt的用法基本一致,只是转换为浮点型数据
‘2.5a‘ ‘a2.5‘
4)强制将数值型和布尔型转为字符串型
toString()
var num=10;
num.toString(); // ‘10‘
3.运算符
表达式:由运算符连接的操作数据,所组成的形式。
运算符分为算术运算符、比较运算符、逻辑运算符、位运算符、赋值运算符、三目运算符
(1)算术运算符
+ - * / % ++ --
% 取余
++ 自增,在原来的基础之上加1
-- 自减,在原来的基础之上减1
console.log(a++); 先打印a的值,然后执行自增
console.log(++a); 先执行自增,然后打印a的值
练习:
var num=3;
console.log( num-- + --num );
(2)比较运算符
> < >= <= == != ===(全等于) !==(全不等于)
返回一个布尔型的值
== 比较两个值是否相等
=== 不仅比较值,还会比较类型是否相等
如果数据类型不同,会发生数据类型转换 |
3>‘10‘ 字符串转为数值 ‘10‘->10
‘3‘>‘10‘ 两个字符串比较的是首个字符的Unicode码
3>‘10a‘ //false
3<‘10a‘ //false
3==‘10a‘ //false
NaN==NaN //false
NaN和任何值比较(> < == >= <= ===),包括自身,都返回false。
(3)逻辑运算符
&& 并且 关联的两个条件都满足,结果是true,否则false
|| 或者 关联的两个条件满足其一,结果是true,否则false
! 非 取反向 !true-> false !false -> true
逻辑短路
&& 当第一个条件为false的时候,就不需要再执行第二个条件
|| 当第一个条件为true的时候,就不需要再执行第二个条件
注意事项:逻辑短路无需关注整个逻辑运算的结果是true还是false,重点是看是否会执行第二个条件
练习:以下程序是否会保错
var num=3; num>5 && console.log(a); num<1 || console.log(a); |
练习:声明变量保存年龄,如果满18岁,打印‘成年人‘
(4)位运算符(了解)
在执行运算的时候,计算机会把数据转成二进制进行运算
1 10 11 100 101 110 111 1000 1001 1010
2 4 8
100101=100000+100+1
32 + 4 + 1 = 37
1010110=1000000+10000+100+10
64 + 16 + 4 + 2=86
25=16+8+1
10000+1000+1=11001
按位与(&) 上下两位都是1,结果是1,否则是0
按位或(|) 上下两位含有1,结果是1,否则是0
按位异或(^) 上下两位不同为1,相同为0
按位右移(>>) 删除二进制的最后一位
按位左移(<<) 在最后一位的后边补0
以上是关于JS的基本数据类型的主要内容,如果未能解决你的问题,请参考以下文章