JS的基本数据类型

JavaScript09

JS的基本数据类型,第1张

JS中一共有六种基本数据类型,分别是Undefined、Null、Boolean、Number、String,还有在ES6中新增的Symbol和ES10中新增的BigInt类型。

1. Undefined:未定义型   

一个变量声明了但是未赋值的情况下就是undefined;

2. Null:空型

一般用来清空变量,也起了占位作用

3. String:字符型

凡是被双引号或单引号包裹起来的都叫做字符型,字符串有length属性。

4. Number:数值型

包含整数和浮点数(浮点数数值必须包含一个小数点,且小数点后面至少有一位数字)两种值。

(1)NaN:非数字类型。

特点:①涉及到的任何关于NaN的操作,都会返回NaN   

           ② NaN不等于自身。

(2)isNaN() :用于检查其参数是不是数值,得到的结果是一个布尔值,不是数值返回true,是数值返回false。

5. Boolean:布尔型

只有true和false两个值。

6. Symbol代表创建后独一无二且不可变的数据类型,它的出现我认为主要是为了解决可能出现的全局变量冲突的问题。

7. BigInt是一种数字类型的数据,它可以表示任意精度格式的整数,使用BigInt可以安全地存储和操作大整数,即使这个数已经超出了Number能够表示的安全整数范围。

    /*  

    1.js中只有一种数据类型

    2.js中的整数会被精确到15位(如果不使用科学计数法)

    3.小数的最大位是17位

    */

    var x = 10

    var y = 20

    var z = "The result is: " + x + y

    console.log('结果为',z)//The result is: 1020

    var a =0.1 + 0.2

    var b =0.3

    console.log('浮点数的值',a,a == b) //0.30000000000000004 false

    /*  

    js中数字相关的方法

    */

    /*  

    返回字符串

    */

    toString()

    /*  

    返回指定位数的字符串值

    不会改变原来数字

    */

    var x = 9.656

    let x0 = x.toFixed(0)           // 返回 10

    let x2 = x.toFixed(2)           // 返回 9.66

    console.log('toFixed',x,x0,x2)   //9.656 10 9.66

    /*  

    返回指定长度的字符串值

    不改变原来的数字

    */

    var x = 9.656

    let xT0 = x.toPrecision()        // 返回 9.656

    let xT2 = x.toPrecision(2)       // 返回 9.7

    console.log('toPrecision',x,xT0,xT2)   //9.656 9.656 9.7

    /*  

    以数值返回数值

    */

    // valueOf()

    /*  

    将js变量转换为数值

    无法转换为数字返回 NaN

    */

    let an = true

    let ar = Number(an)

    console.log('Number',ar)

    /*  

    解析一段字符串返回数字

    允许空格。只返回首个数字:

    */

    parseInt("10")         // 返回 10

    parseInt("10.33")      // 返回 10

    parseInt("10 20 30")   // 返回 10

    parseInt("10 years")   // 返回 10

    parseInt("years 10")   // 返回 NaN

    /*  

    解析一段字符串并返回数值。允许空格。只返回首个数字:

    */

    parseFloat("10")        // 返回 10

    parseFloat("10.33")     // 返回 10.33

    parseFloat("10 20 30")  // 返回 10

    parseFloat("10 years")  // 返回 10

    parseFloat("years 10")  // 返回 NaN