JS数据类型和类型转换

目录

数据类型

typeof运算符检查数据类型

1.String 字符串

2.Number 数值

3.Boolean 布尔值

4.Null 空值

5.Undefined 未定义

6.null 和 undefined

类型转换

转换为String

转换为Number

转换为布尔值


数据类型

六种数据类型:JS中一共分成六种数据类型 5个基本数据类型+object

基本数据类型:

String字符串
Number数值
Boolean布尔值
Null空值
Undefined未定义

   undefined和null,一般将它们看成两个特殊值。

引用数据类型

Object对象

        对象:

  • 狭义的对象(object)
  • 数组(array)
  • 函数(function)

typeof运算符检查数据类型

数值

number

字符串

string

布尔值

boolean

undefined

undefined

null

object

对象

object

函数

function


1.String 字符串

JS中的字符串放在单引号或者双引号中。

1)在字符串中使用\作为转义字符

  • \0 :null
  • \b :后退键
  • \f :换页符
  • \n :换行符
  • \r :回车键
  • \t :制表符
  • \v :垂直制表符
  • \' :单引号
  • \" :双引号
  • \\ :反斜杠

2)连接运算符(+)可以连接多个单行字符串,将长字符串拆成多行书写,输出的时候也是单行。

3)length属性:length属性返回字符串的长度。

var a = "hello";
a.length = 5;


2.Number 数值

1)JS中所有的整数和浮点数都是Number类型

2)数值范围:

数值的范围:  Number.MIN_VALUE 最小值 5e-324

                        Number.MAX_VALUE 最大值 1.7976931348623157e+308

数值范围检测:

                        使用 isFinite()函数可以判断参数是否在最大值和最小值之间,如果在,返回true

3)特殊的数字:能赋值给变量

Infinity 正无穷 

        Infinity大于一切数值(除了NaN)

a = Infinity ,能赋值

-Infinity 负无穷

        -Infinity小于一切数值(除了NaN)

NaN 非法数字(Not A Number)

        NaN不等于任何值,与任何值进行运算,得到的都是NaN

4)其他进制的数字的表示:

        0b 开头表示二进制,但是不是所有的浏览器都支持

        0 开头表示八进制

        0x 开头表示十六进制

        使用typeof检查一个Number类型的数据时,会返回”number”(包括NaN 和 Infinity)

 5)与数值相关的方法

          parseInt()  :将字符串转为整数。

      如果字符串的第一个字符不能转化为数字(后面跟着数字的正负号除外),返回NaN。

        parseFloat() :将一个字符串转为浮点数。

      如果参数不是字符串,或者字符串的第一个字符不能转化为浮点数,则返回NaN。

        isNaN() :判断是否是数值

        isFinite() :返回一个布尔值,表示某个值是否为正常的数值。

除了Infinity、-Infinity、NaN和undefined这几个值会返回false,isFinite对于其他的数值都会返回true。


3.Boolean 布尔值

1)布尔值主要用来进行逻辑判断,布尔值只有两个

true 逻辑的真   1

false 逻辑的假  0

2)

  • 两元逻辑运算符: && (And),|| (Or)
  • 前置逻辑运算符: ! (Not)
  • 相等运算符:===,!==,==,!=
  • 比较运算符:>,>=,<,<=

3)转换为Boolean,下面六个为false,其他均为true

  • undefined
  • null
  • false
  • 0
  • NaN
  • ""或''(空字符串)

注意,空数组([ ])和空对象({ })对应的布尔值,都是true。

使用typeof检查一个布尔值时,会返回”boolean”


4.Null 空值

空值专门用来表示为空的对象,Null类型的值只有一个

null

使用typeof检查一个Null类型的值时会返回”object”(因为历史遗留问题)


5.Undefined 未定义

如果声明一个变量但是没有为变量赋值此时变量的值就是undefined

该类型的值只有一个 undefined

使用typeof检查一个Undefined类型的值时,会返回”undefined”


6.null 和 undefined

null是一个表示“空”的对象,转为数值时为 0 ;

undefined是一个表示”此处无定义”的原始值,转为数值时为 NaN 。

null表示空值,即该处的值现在为空。调用函数时,某个参数未设置任何值,这时就可以传入null,

undefined表示“未定义”,


类型转换

类型转换就是指将其他的数据类型,转换为String Number 或 Boolean


转换为String

方式一(强制类型转换):

调用被转换数据的toString()方法

var a = 123;
a = a.toString();

注意:这个方法不适用于null和undefined
由于这两个类型的数据中没有方法,所以调用toString()时会报错

方式二(强制类型转换):

调用String()函数

var a = 123;  
a = String(a);

原理:对于Number Boolean String都会调用他们的toString()方法来将其转换为字符串,对于null值,直接转换为字符串”null”。对于undefined直接转换为字符串”undefined”

方式三(隐式的类型转换):

为任意的数据类型 +" "

var a = true;  
a = a + "";

原理:和String()函数一样


转换为Number

方式一(强制类型转换):

调用Number()函数

var s = "123";  
s = Number(s);

转换的情况:

  1. 字符串 > 数字
    如果字符串是一个合法的数字,则直接转换为对应的数字
    如果字符串是一个非法的数字,则转换为NaN
    如果是一个空串或纯空格的字符串,则转换为0
  2. 布尔值 > 数字
    true转换为1
    false转换为0
  3. 空值 > 数字
    null转换为0
  4. 未定义 > 数字
    undefined 转换为NaN

方式二(强制类型转换):

调用parseInt()或parseFloat()
这两个函数专门用来将一个字符串转换为数字的

如果对非String使用parseInt()或parseFloat(),它会先将其转换为String然后在操作 parseInt()
可以将一个字符串中的有效的整数位提取出来,并转换为Number

var a = "123.456px";  
a = parseInt(a); //123

如果需要可以在parseInt()中指定一个第二个参数,来指定进制parseFloat()可以将一个字符串中的有效的小数位提取出来,并转换为Number

var a = "123.456px";  
a = parseFloat(a); //123.456

方式三(隐式的类型转换):

使用一元的+来进行隐式的类型转换

var a = "123";  
a = +a;

原理:和Number()函数一样


转换为布尔值

方式一(强制类型转换):

使用Boolean()函数

var s = "false";  
s = Boolean(s); //true

转换的情况
字符串 > 布尔
除了空串其余全是true

数值 > 布尔
除了0和NaN其余的全是true

null、undefined > 布尔
都是false

对象 > 布尔
都是true

方式二(隐式类型转换):

为任意的数据类型做两次非运算,即可将其转换为布尔值

var a = "hello";  
a = !!a; //true

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值