JS简单数据类型

更新日期: 2020-04-17阅读: 2k标签: 类型

一、数据类型简介

1、为什么需要数据类型

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

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


2、变量的数据类型

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

var age = 10;        //这是一个数字型
var areYouk = '是的' //这是一个字符串

代码运行时,变量的数据类型是有JS引擎根据 = 右边变量值得数据类型来判断的,运行完毕之后,变量就确定了数据类型 JavaScript拥有动态类型,同事也意味着相同的变量可用作不同的类型:

var x = 6;      //x为数字
var x = 'Bill'; //x为字符串


3、数据类型的分类

JS把数据类型分为两类:

简单数据类型(Number,String,Boolean,Underfined,Null)

复杂数据类型(object)


二、简单数据类型

1、简单数据类型(基本数据类型)

Number 数字型,包含整型值和浮点型值,如21、0.21 ,默认值:0

Boolean 布尔值类型,如true、false,等价于1和0,默认是:false

String 字符串类型,如“张三” 注意咱们JS里面,字符串都带引号,默认值:""

Undefined var a;声明了变量a但是没有给值,此时a = undefined,默认值:undefined

Null var a = ull;声明了变量a为空值,默认值:null


2、数字型 Number

JavaScript 数字类型既可以用来保存整数值,也可以保存小数(浮点数)。

var age = 21;     //整数
var Age = 21.3578 //小数

2.1、数字型进制

最常见的进制有二进制、八进制、十进制、十六进制

//1.八进制数字序列范围:0~7
var num1 = 01; //对应十进制的7
var num2 = 019;//对应十进制的19
var num3 = 08; //对应十进制的8
//2.十六进制数字序列范围:0~9以及A~F
var num = 0xA;

现阶段我们只需要记住,在JS中八进制前面加0,十六进制前面加0x 例子:

//1.八进制 0~7 我们程序员里面数字前面加0 表示八进制
var num1 = 010;
console.log(num1); //010 八进制 转换为10进制 就是8
var num2 = 012;
console.log(num2);
//2.十六进制 0~9 a~f #ffffff 数字的前面加0x 表示十六进制
var num3 = 0x9;
console.log(num3);
var num4 = 0xa;
console.log(num4);

2.2、数字型范围

JavaScript 中数值的最大和最小值

alert(Number.MAX_VALUE); //1.7976931348623157e+308
alert(Number.MIN_VALUE); //5e-324

2.3、数字型三个特殊值

alert(Infinity);  //Infinity
alert(-Infinity); //-Infinity
alert(NaN);       //NaN

Infinity ,代表无穷大,大于任何数值

-Infinity ,代表无穷小,小于任何数值

NaN ,Not a number ,代表一个非数值 例子:

//3.数字型的最大值
console.log(Number.MAX_VALUE);
//4.数字型的最小值
console.log(Number.MIN_VALUE);
//5.无穷大
console.log(Number.MAX_VALUE * 2);//Infinity 无穷大
//6.无穷小
console.log(-Number.MAX_VALUE * 2);//-Infinity 无穷小
//7.非数字 (字符串减不了数值,所以是一个非数值NaN)
console.log('pink老师' - 100) // NaN

2.4、isNaN()

用来判断一个变量是否为非数字的类型,返回true或者false

x是数字,返回false
isNaN(x)   x是一个非数字类型
 x不是数字,返回true

例子:

console.log (isNaN(12)); //false
console.log(isNaN('pik老师') //true

3、字符串型 String

字符串型可以使引号中的任意文本,其语法为双引号""和单引号''

var strMsg = '我爱天安门'; //用单引号表示字符串
var strMsg2 = "pki猪";    //用双引号表示字符串
var strMsg3 = 我爱大肘子;  //报错,没使用引号,会被认为是Js代码,但Js没有这些语法

因为html标签里面的属性使用的是双引号,JS这里我们更推荐使用单引号.

3.1、字符串引号嵌套

JS可以用单引号嵌套双引号,或者用双引号嵌套单引号(外双内单,外单内双)

var strMsg = '我是"高帅富"程序员'; //可以用''包含""
var strMsg2 = "我是'高富帅'程序员"; //可以用""包含''
//常见错误
var badQuotes = 'what on earth?"; //报错,不能单双引号搭配

3.2、字符串转义符

类似HTML里面的特殊字符,字符串中也有特殊字符,我们称之为转义符。 转义符都是\开头的,常用的转义符及其说明如下:

\n,换行符,n是newline的意思

\ ,斜杠\

','单引号

","双引号

\t,tab缩进

\b,空格,b是blank的意思

3.3、字符串长度

字符串是由若干字符组成的,这些字符的数量就是字符串的长度。通过字符串的length属性可以获取整个字符串的长度。

var strMsg = "我是程序员";
alert(strMsg.length);//显示5

3.4、字符串拼接

多个字符串之间可以使用 + 进行拼接,其拼接方式为字符串 + 任何类型 = 拼接之后的新字符串

拼接前会把与字符串相加的任何类型转成字符串,在拼接一个新的字符串

//字符串的拼接 + 只要有字符串和其他类型相拼接 最终的结果是字符串
console.log('沙漠' + '骆驼'); //字符串的 沙漠骆驼
console.log('pink老师'+18); //'pink老师18'
console.log('pink' + true); //pinktrue
console.log(12 + 12); //24
console.log('12' + 12); //'1212'

+ 号总结口诀:数值相加,字符相连

3.5、字符串拼接加强

console.log('pink老师' + 18);
console.log('pink老师' + 18 +'岁');
var age = 19;
console.log('pink老师age岁'); 
// 我们变量不要写到字符串里面,是通过和 字符串相连的方式实现的
console.log('pink老师'+ age +'岁');
//变量和字符串相连的口诀:引引加加
console.log('pink老师' + age + '岁');

我们经常会将字符串和变量来拼接,因为变量可以很方便地修改里面的值

变量是不能添加引号的,因为加引号的变量会变成字符串

如果变量两侧都有字符串拼接,口诀“引引加加”,删掉数字,变量写加中间

3.6、案例:显示年龄

弹出一个输入框,需要用户输入年龄,之后弹出一个警示框显示“您今年XX岁啦”(xx表示刚才输入的年龄)

//弹出一个输入框(prompt),让用户输入年龄(用户输入)
//把用户输入的值用变量保存起来,把刚才输入的年龄与所要输出的字符串拼接(程序内部处理)
//使用alert语句弹出警示框(输出结果)
var age = prompt('请输入您的年龄:');
var str = '您今年' + age + '岁';
alert(str);

4、布尔型 Boolean

布尔类型有两个值:true 和 false,其中true表示真(对),而false表示假(错) 布尔型和数字型相加的时候,true的值为1,false的值为0.

var flag = true;  //flag 布尔型
var flag1 = false;//flag1 布尔型
console.log(flag + 1); //2
console.log(flag1 + 1);//1

5、Undefined 和 Null

一个声明后没有被赋值的变量会有一个默认值undefined(如果进行相连或者相加时,注意结果)

//如果一个变量声明未赋值 就是 undefined 未定义数据类型
var str;
console.log(str);
var variable = undefined;
console.log(variable + 'pink'); //undefinedpink
console.log(variable + 1); //NaN undefined 和数字相加 最后的结果是NaN

一个声明变量给null值,里面存的值为空

var space = null;
console.log(space + 'pink'); //nullpink
cnsole.log(space + 1); //1

6、字面量

字面量是在源代码中一个固定值的表示法,通俗来说,就是字面量表示如何表达这个值

数字字面量:8,9,10

字符串面量:'程序员',"前端"

布尔字面量:true,false


三、数据类型转换

1、什么是数据类型转换

使用表单、prompt获取过来的数据默认是字符串类型的,此时就不能直接简单的进行加法运算,而需要转换变量的数据类型。通俗来说,就是把一种数据类型的变量转换成另外一种数据类型. 我们通常会实现3种方式的转换:

转换为字符串类型

转换为数字型

转换为布尔型


2、转换为字符串

toString(),转成字符串

String()强制转换,转成字符串

加号拼接字符串,和字符串拼接的结果都是字符串

// 1.把数字型转换为字符串型 变量.toStrng()
var num = 10;
var str = num.toString();
console.log(str);
console.log(typeof str);
// 2.我们利用 String(变量)
console.log(String(num));
// 3.利用 + 拼接字符串的方法实现转换效果 隐式转换
console.log(num + '');

toString()和String()使用方式不一样

三种转换方式,我们更喜欢使用第三种加号拼接字符串转换方式,这一种方式也称之为隐式转换


3、转换为数字型(重点)

parseInt(string)函数,将string类型转成整数数值型,parseInt('78')

parseFloat(string)函数,将string类型转成浮点数数值型,parseFloat('78.11') *、Numer()强制转换函数,将string类型转换为数值型,Number('12')

JS隐式转换(- * /),利用算术运算隐式转换为数值型,'12' - 0

// var age = prompt('请输入您的年龄');
// 1. parseInt(变量) 可以把 字符型的转换为数字型 得到是整数
// console.lg(parseInt(age));
console.log(parseInt('3.14')); // 3取整
console.log(parseInt('3.94')); // 3取整
console.log(parseInt('120px')); // 120 会去到这个px单位
console.log(parseInt('rem120px')); // NaN
// 2. parseFloat(变量) 可以把 字符型的转换为数字型 得到是小数 浮点数
console.log(parseFloat('3.14')); // 3.14
console.log(parseFloat('120px')); // 120 会去到这个px单位
console.log(parseFloat('rem120px')); // NaN
// 3. 利用 Number(变量)
var str = '123';
console.log(Number(str));
console.log(Numbr('12'));
// 4. 利用了算术运算 - * / 隐式转换
console.log('12' - 0); // 12
console.lg('123' - '120');
console.log('123' * 1);

注意 parseInt 和 parseFloat 单词的大小写,这2个是重点

隐式转换使我们在进行算术运算的时候,JS自动转换了数据类型

3.1、案例 1:计算年龄

要求在页面中弹出一个输入框,我们输入出生年份后,能计算出我们的年龄。

// 弹出一个输入框(prompt),让用户输入出生年份 (用户输入)
// 把用户输入的值用变量保存起来,然后用今年的年份减去变量值,结果就是现在的年龄(程序内部处理)
// 弹出警示框(alert),把计算的结果输出(输出结果)
var year = prompt('请输入您的出生年份');
var age = 2020 - year; // year 取过来的是字符串型 但是这里用的减法 有隐式转换
alert('您的年龄是:' + age + '岁');

3.2、案例 2:简单加法器

计算两个数的值,用户输入第一个值后,继续弹出第二个输入框并输入第二个值,最后通过弹出窗口显示出两次输入值相加的结果。

// 先弹出第一个输入框,提示用户输入第一个值 保存起来
// 在弹出第二个框,提示用户输入第二个值 保存起来
// 把这两个值相加,并将结果赋给新的变量(注意数据类型转换)
//弹出警示框(alert),把计算的结果输出(输出结果)
````javasript
var num1 = prompt('请输入第一个值:');
var num2 = prompt ('请输入第二个值:');
var result = parseFloat(num1) + parseFloat(num2);
alert('结果为:' + rsult);

4、转换为布尔型

Boolean()函数,说明:其他类型转成布尔值,案例:Boolean('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

代表空、否定的值会被转换喂false,如''、0、NaN、null、undefined

其余值都会被转换为true



链接: https://fly63.com/article/detial/9476

JS中Null与Undefined的区别

在JavaScript中存在这样两种原始类型:Null与Undefined。这两种类型常常会使JavaScript的开发人员产生疑惑,在什么时候是Null,什么时候又是Undefined?Undefined类型只有一个值,即undefined。当声明的变量还未被初始化时,变量的默认值为undefined。

Javascript的类型检测

主要介绍了JS中检测数据类型的几种方式,typeof运算符用于判断对象的类型,但是对于一些创建的对象,它们都会返回\'object\',有时我们需要判断该实例是否为某个对象的实例,那么这个时候需要用到instanceof运算符

js类型转换的各种玩法

对于object和number、string、boolean之间的转换关系,ToPrimitive是指转换为js内部的原始值,如果是非原始值则转为原始值,调用valueOf()和toString()来实现。

JavaScript类型:关于类型,有哪些你不知道的细节?

Undefined类型表示未定义,它的类型只有一个值为undefined。undefined和null有一定的表意差别。非整数的Number类型无法使用 == 或 === 来比较,因为 JS 是弱类型语言,所以类型转换发生非常频繁

为你的 JavaScript 项目添加智能提示和类型检查

近在做项目代码重构,其中有一个要求是为代码添加智能提示和类型检查。智能提示,英文为 IntelliSense,能为开发者提供代码智能补全、悬浮提示、跳转定义等功能,帮助其正确并且快速完成编码。

js的类型

基本类型:按值访问,可以操作保存在变量中实际的值;引用类型数据存在堆内存,而引用存在栈区,也就是说引用类型同时保存在栈区和堆区,关于==的执行机制,ECMASript有规范,因为==前后的值交换顺序,返回的值也是一样的,所以在此对规范做出如下总结

再也不用担心 JavaScript 的数据类型转换了

JavaScript 是一种弱类型或者说动态类型语言。所以你不用提前声明变量的类型,在程序运行时,类型会被自动确定,你也可以使用同一个变量保存不同类型的数据。

JavaScript基础之值传递和引用传递

js的值传递和引用(地址)传递:js的5种基本数据类型 number,string,null,undefined,boolean 在赋值传递时是值传递,js的引用数据类型(object,array,function)进行引用传递,其实底层都是对象。

JS中的布尔 数字 字符串

JS中所有的值都可以转换成布尔类型 使用Boolean()或者 !!(两个感叹号),JS中所有的值都可以转换成数字类型,使用Number()或+。数字类型转换场景目的只有一个,用于计算,将后台传递的数据,从字符串转换为数字并参与计算

if条件中,js的强制类型转换

众所周知,JS在很多情况下会进行强制类型转换,其中,最常见两种是:1.使用非严格相等进行比较,对==左边的值进行类型转换2.在if判断时,括号内的值进行类型转换,转化为布尔值

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!