数据类型
1.数据类型简介
1.1 为什么需要数据类型
在计算机中,不同的数据所需占用的存储空间是不同的,为了便于把数据分成所需内存大小不同的数据,充分利用存储空间,于是定义了不同的数据类型。
简单来说。数据类型就是数据的类别型号。比如姓名“张三”,年龄18,这些数据的类型是不一样的。
1.2 变量的数据类型
var age = 10;//这是一个数字型
Var areYouOK = '是的';//这是一个字符型
在代码运行时,变量的数据类型是由JS引擎根据 = 右边变量值的数据类型来判断的,运行完毕之后,变量就确定了数据类型。
JavaScript拥有动态类型,同时也意味着相同的变量可用作不同的类型;
var x = 6;//x 为数字
var areYouOK = '是的';//x 为字符串
1.3数据类型的分类
JS把数据类型分为两类:
-
简单数据类型(number,string,Boolean,Undefined,Null)
-
复杂数据类型(object)
2.简单数据类型
2.1简单数据类型(基本数据类型)
JavaScript中的简单数据类型及其说明如下:
简单数据类型 | 说明 | 默认值 |
---|---|---|
Number | 数字型,包含整型值和浮点型值,如21、0.21 | 0 |
Boolean | 布尔值类型,如true、false,等价于1和0 | false |
String | 字符串类型,如“张三” 注意咱们JS里面,字符串都带引号 | “ ” |
Undefined | var a;声明了变量a但是没有给值,此时a = undefined | undefined |
Null | var a = null;声明了变量a 为空值 | null |
2.2 数字型Number
JavaScript数字类型既可以用来保存整数值,也可以保存小数(浮点数)。
var age = 21;//整数
var Age = 21.3747;//小数
1.数字型进制
最常见的进制有二进制、八进制、十进制、十六进制。
//1.八进制数字序列范围:0~7
var num1 = 07;//对应十进制的7
var num2 = 019;//对应十进制的19
var num3 = 08;//对应十进制的8
//2.十六进制数字序列范围:0~9以及A~F
var num = 0xA;
现阶段我们只需记住,在JS中八进制前面加 0 ,十六进制前面加 0x .
2.数字型范围
JavaScript中数值的最大和最小值
alert(Number.MAX_VALUE);//1.7976931348623157e+308
alert(Number.MIN_VALUE);//5e-324
3.数字型三个特殊值
alert(Infinity);//Infinity
alert(-Infinity);//-Infinity
alert(NaN);//NaN
-
Infinity,代表无穷大,大于任何数值
-
-infinity,代表无穷小,小于任何数值
-
NaN,Not a number,代表一个非数值
4.isNaN()
用来判断一个变量是否为非数字类型,返回true或者false
isNaN(X) X是数字,返回false;X不是数字,返回true
console.log(isNaN(12));//false,21不是一个非数字
console.log(isNaN('MENG'));//true,“andy”是一个非数字
2.3 字符串型 String
字符串型可以是引号中的任意文本,其语法为双引号“”和单引号’‘
var strMsg1 = "我爱北京天安门";//双引号
var strMsg2 = '我爱我家';//单引号
var strMsg3 = 大猪蹄子;//错误的写法
因为HTML标签里的属性使用的是双引号,JS这里更推荐使用单引号。
1.字符串引号嵌套
JS可以用单引号嵌套双引号,或者用双引号来嵌套单引号(外双内单,外单内双)
var strMsg1 = "我爱'北京'天安门";
var strMsg2 = '我"爱"我家';
2. 字符串转义符
类似HTML里面的特殊字符,字符串也有特殊字符,我们称之为转义符。
转义符都是\开头的,常用的转义符及其说明如下:
转义符 | 解释说明 |
---|---|
\n | 换行符,n是newline的意思 |
\ | 斜杠\ |
' | ' 单引号 |
" | “ 双引号 |
\t | tab 缩进 |
\b | 空格,b是blank 的意思 |
3.字符串长度
字符串是由若干字符组成的,这些字符的数量就是字符串长度,通过字符串的length属性可以获取整个字符串的长度。
var strMsg1 = "漂亮的小姐姐呀";
console.log(strMsg1.length);//显示7
4.字符串拼接
-
多个字符串之间可以使用+进行拼接,其拼接方式为 字符串+任何类型=拼接之后的新字符串
-
拼接前会把与字符串相加的任何类型转成字符串,再拼接成一个新的字符串
// 1.字符串“相加”
alert('hello' + ' ' + 'world');//hello world
// 2.数值字符串“相加”
alert('100' + '100');//100100
// 3.数值字符串+数值
alert('11' + 12);//1112
+号总结口诀:数值相加,字符相连
5. 字符串拼接加强
console.log('小小强' + 18);//只要有字符串就会相连
var age = 18;
// console.log('小小强18岁了');//这样写是不行的
console.log('小小强' + age);//小小强18
console.log('小小强' + age + '岁啦');//小小强18岁啦
-
我们经常会将字符串和变量来拼接,因为变量可以很方便地修改里面的值
-
变量是不能添加引号的,因为加引号的变量会变成字符串
-
如果变量两侧都有字符串拼接,口诀”引引加加“,删除数字,变量写加中间
2.5 布尔型 Boolean
布尔类型有两个值:true和false,其中true表示真(对),而false表示假(错)。
布尔型和数字型想家的时候,true的值为1,false的值为0;
console.log(flag + 1);//输出2 true 参与运算当1来算
console.log(flag1 + 1);//输出1 false 参与运算当1来算
2.6 Undefined和Null
一个声明后没有被赋值的变量会有一个默认值undefined(如果进行相连或者相加时,注意结果)
var str;
console.log(str);//输出undefined
var visible = undefined;
console.log(visible + '小小强');//undefined小小强
console.log(visible + 1);//NaN
一个声明变量给null值,里面存的值为空(学习对象时,我们继续研究null)
var space = null;
console.log(space + '小小强');//null小小强
console.log(space + 1);//1
3.获取变量数据类型
3.1 获取检测变量的数据类型
typeof可用来获取检测变量的数据类型
var num = 10;
console.log(typeof num);//数字型
var str = '小小强';
console.log(typeof str);//字符型
var flag = true;
console.log(typeof flag);//布尔型
var vari = undefined;
console.log(typeof vari);//未定义类型
var space = null;
console.log(typeof space);//object
//prompt 取过来的值是字符串型
var age = prompt('请输入你的年龄');
console.log(age);
console.log(typeof age);
3.2字面量
字面量是源代码中一个固定值的表示法,通俗来说,就是字面量表示如何表达这个值。
-
数字字面量:8,9,10
-
字符串字面量:'黑马',”前端“
-
布尔字面量:true,false
4.数据类型转换
4.1 什么是数据类型转换
使用表单、prompt获取过来的数据默认是字符串类型的,此时就不能直接简单的进行加法运算,而需要转换变量的数据类型。通俗来说,就是把一种数据类型的变量转换成另外一种数据类型
我们通常会实现3种方式的转换:
-
转换为字符串类型
-
转换为数字型
-
转换为布尔型
4.2 转换为字符串
方式 | 说明 | 案例 |
---|---|---|
toString()(了解) | 转成字符串 | var num=1;alert(num.toString()); |
String(了解) | 转成字符串 | var num = 1;alert(String(num)); |
加号拼接字符串(重点) | 和字符串拼接的结果都是字符串(隐式转换) | var num = 1;alert(num+"我是字符串"); |
//1.数字型转换为字符串 变量.toString()
var num = 10;
var str = num.toString();
console.log(str);
//2.String(变量)
console.log(String(num));
//加号拼接字符串
console.log(num + '');
4.3 转换为数字型(重点)
方式 | 说明 | 案例 |
---|---|---|
parseInt(string)函数 | 将string类型转成为整数数值型 | parseInt('78') |
parseFloat(string)函数 | 将string类型转成为浮点数数值型 | parseFloat('78') |
Number()强制转换函数 | 将string类型转换为数值型 | Number('12') |
js隐式转换(- * /) | 利用算术运算隐式转换为数值型 | '12'-0 |
var age = prompt('请输入你的年龄');
//1.ParseInt(变量) 可以把字符型的转换为数字型 得到整数
console.log(parseInt(age));
console.log(parseInt('3.14'));//取整
console.log(parseInt('3.94'));//取整
console.log(parseInt('120px'));//120 px这个单位会被去掉
console.log(parseInt('rem120px'));//NaN
//2.ParseFloat(变量) 可以把字符型的转换为数字型 得到小数
console.log(parseFloat('3.94'));
console.log(parseFloat('120px'));//120 px这个单位会被去掉
console.log(parseFloat('rem120px'));//NaN
注意:
-
parseInt 和 parseFloat 单词的大小写,这两个是重点
-
隐式转换是我们在进行算术运算的时候,JS自动转换了数据类型
4.4 转换为布尔型
方式 | 说明 | 案例 |
---|---|---|
Boolean()函数 | 其他类型转成布尔值 | Boolean('true'); |
-
代表空、否定的值会被转换为false,如 ” 、0 、NaN、null、undefined
-
其余值都会被转换为true
console.log(Boolean(''));//false
console.log(Boolean('0'));//false
console.log(Boolean('NaN'));//false
console.log(Boolean('null'));//false
console.log(Boolean('undefined'));//false
console.log(Boolean('小小强'));//true
console.log(Boolean(12));//true
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步