数据类型

数据类型

1.数据类型简介

1.1 为什么需要数据类型

在计算机中,不同的数据所需占用的存储空间是不同的,为了便于把数据分成所需内存大小不同的数据,充分利用存储空间,于是定义了不同的数据类型。

简单来说。数据类型就是数据的类别型号。比如姓名“张三”,年龄18,这些数据的类型是不一样的。

1.2 变量的数据类型

变量是用来存储值的所在处,他们由名字和数据类型。变量的数据类型决定了如何将代表这些值的位存储到计算机的内存中去。JavaScript是一种弱类型或者说动态语言。这意味着不用提前声明变量的类型,在程序运行过程中,类型会被自动确定。

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
posted @ 2020-08-23 23:43  행운의소녀  阅读(428)  评论(0编辑  收藏  举报