js数据类型
数据类型
数据类型指的就是字面量的类型。
js有6种数据类型:String 字符串、Number 数值、 Boolean 布尔值、Null 空值、Undefined 未定义、Object 对象。
基本数据类型
一、String
// 用引号括起来,单引号和双引号都可以,但是不能混搭。
var a = 'hello';
var b = "world";
// 错误示例
var c = 'hello";
另,转义符号:
/**
\" 表示 "
\' 表示 '
\n 表示 换行
\t 表示 制表符
\\ 表示 \
**/
// 单引号和双引号嵌套使用
var str = '我说:"今天的天气不错!"';
// 使用转义字符
str = "我说:\"今天的天气不错!\"";
// 错误示例
str = "我说:"今天的天气不错!""
二、Number
/**
在js中所有数值都是Number类型,包括整数和浮点数
**/
var a = 123;
var b = 123.456;
// 可以使用typeof来检查一个变量的类型
console.log(typeof a); // number
var c = "123";
console.log(typeof c); // string
var d = Number.MAX_VALUE; // 最大数值 d = 1.7976931348623157e+308
console.log(typeof d); // number
//如果数值超过数值能表示的最大值,则返回Infinity。
console.log(d * d); //Infinity
// 错误示例
console.log(typeof d*d); // NaN
// 正确示例(需要括号)
console.log(typeof (d*d)); // number
//如果小于数值能表示的最小值,则返回-Inifinity。
console.log(-Number.MAX_VALUE * Number.MAX_VALUE); //-Infinity
a = "abc" * "bcd";
console.log(typeof a); // NaN NaN是一个特殊的数字,表示的是Not a Number
a = Infinity;
console.log(typeof a); // number
a = NaN ;
console.log(typeof a); // number
a = Number.MIN_VALUE;
console.log(a); //5e-234 正数中能表示的最小值,并不是Number取值的最小值
注意:在js中的整数的基本运算基本可以保证精确,但是可能会出现不精确的情况,因为在2进制中不能表示1/10。所以千万不要使用js进行对精确度要求比较高的运算。
三、Boolean
// Boolean的布尔值只有两个,一个是true,一个是false
var bool = true;
console.log(bool); // true
console.log(typeof bool); // boolean
四、Null
// Null类型的值只有一个,就是 null,专门用来表示为一个空的对象
var a = null ;
console.log(a); // null
console.log(typeof a); // object
五、Undefined
// Undefined 类型的值只有一个,就是 undefined
var b;
console.log(b); //undefined 表示未定义,声明了未赋值
console.log(typeof b); // undefined
强制类型转换
强制类型转换,指的是将一个数据类型强制转换成其他的数据类型。类型转换主要指将其他的数据类型转换为String、Number、Boolean。
一、将其他数据类型转换成String
方式一:调用被转换数据类型的toString()方法,该方法不会改变原变量。但是注意,null 和undefined 这两个值没有toString()方法。
var a = 123;
a = a.toString(); // "123"
var b = false
b = b.toString(); // "false"
var c = null
c = c.toString(); // 会报错
var d = undefined
d = d.toString(); // 会报错
方式二:调用String()函数,并将被转换的变量作为参数传递给函数,该函数不会改变原变量,对于Number和Boolean实际上就是调用的toString()方法,对于null直接转换为“null”,将undefined直接转换为"undefined"。
var a = 123;
a = String(a); // "123"
var b = false
b = String(b); // "false"
var c = null
c = String(c); // "null"
var d = undefined
d = String(d); // "undefined"
二、将其他数据类型转换成Number
方式一:使用Number函数
- 字符串转数值
1.如果是纯数字的字符串,直接转换成数字
2.如果字符串中有非数字的内容,则转换为NaN
3.如果是空字符串或者全是空格的字符,则转换为0 - 布尔值转数值,true转换为1,false转换为0
- null转数值,转换为0
- undefined转数值,转换为NaN
方式二:专门用来对付字符串
- parseInt() 把一个字符串转换为一个整数
- parseFloat() 把一个字符串转换为一个浮点数
var a = "123";
console.log(a); // "123"
console.log(typeof a); // string
a = Number(a); // number 123
var str = 'hello';
str = Number(str); // number NaN
a = "123px";
// parseInt可以将字符串中有效的整数取出来,再转换为Number
a = parseInt(a); // 123
a = 'b1234ddd';
a = parseInt(a); // NaN
a = '123.456px';
a = parseFloat(a); // 123.456
a = '123px';
a = parseFloat(a); // 123
// 如果对非String使用parseInt()和parseFloat(),它会先将其转换为String,然后再操作。
a = true;
a = parseInt(a); // NaN
// 等同于
a = parseInt("true");
a = 198.23;
a = parseInt(a); // 198
// 在js中,如果需要表示16进制的数字,则需要以0x开头
// 如果需要表示8进制的,则需要以0开头
// 如果要表示2进制数字,则需要以0b开头,但不是所有浏览器都支持。
a = 0x10; // 16进制 16
a = 0xff; // 16进制 255
a = 070; // 8进制 56
a = "070"; //这种字符串,有些浏览器会当成8进制解析,有些会当成10进制解析
a = parseInt(a, 10); //可以传递第二个参数,来指定数字的进制
三、将其他数据类型转换成Boolean
使用Boolean()函数
- Number:除了0和NaN,其余都是true
- String: 除了空串,其余都是true
- null和undefined都会转换为false
- 对象都会转换为true
var a = 123;
a = Boolean(a); // true
a = -123;
a = Boolean(a); // true
a = Infinity;
a = Boolean(a); // true
a = 0;
a = Boolean(a); // false
a = NaN;
a = Boolean(a); // false
a = 'true';
a = Boolean(a); // true
a = ''
a = Boolean(a); // false
a = ' '
a = Boolean(a); // true
a = null
a = Boolean(a); // false
a = undefined
a = Boolean(a); // false