一、数据类型简介:
1.JavaScript(以下简称js)的数据类型分为两种:原始类型(即基本数据类型)和对象类型(即引用数据类型);
2.js常用的基本数据类型包括undefined、null、number、boolean、string;
3.js的引用数据类型也就是对象类型Object,比如:Object、array、function、data等;
二、基本数据类型特点:
1.基本数据类型是按值访问的,就是说我们可以操作保存在变量中的实际的值;
2.基本数据类型的值是不可变的,任何方法都无法改变一个基本数据类型的值,比如一个字符串:
let name = 'zhangsan'
name.substr()
console.log(name) // 输出:zhangsan
let age = 'firstblood'
age.toUpperCase()
console.log(age) // 输出:firstblood
通过上面的例子,我们可以发现原来定义的变量name的值始终没有发生改变,而调用substr()和toUpperCase()方法后返回的是一个新的字符串,跟原来定义的变量name并没有什么关系。
再看下面的代码:
let name = 'zhangsan'
name = 'lisi'
console.log(name) // 输出:lisi
上面的例子看来name的值好像“改变了”,这里的基础数据类型是string,也就是“zhagnsan”,这里的“zhangsan”是不可以改变的,name只是指向“zhagnsan”的一个指针,指针的指向不可以改变,所以下面的name = 'lisi',将name指向了“lisi”,这里的“lisi”也是不可以改变的。也就是说这里的改变只是“指针指向的改变”。
3.基本数据类型不可以添加属性和方法:
let user = 'zhangsan'
user.age = 18
user.method = function () {
console.log('12345')
}
console.log(user.age) // 输出:undefined
console.log(user.method) // 输出:undefined
上面的代码可以看出,基本数据类型是不能添加属性和方法的,再次说明基本数据类型是不可变的。
4.基本数据类型的赋值是简单的赋值(如果从一个变量向另一个变量赋值基本类型的值,会在变量对象上创建一个新值,然后把该值赋值到位新变量分配的位置上):
let a = 18
let b = a
a++
console.log(a) // 输出:19
console.log(b) // 输出:18
上面的代码,a中保存的值是18,当使用a的值来初始化b时,b中也保存了值18,但是b中的18和a中的18完全是独立的,b中的值只是a中值的一个副本,所以这两个变量可以参与任何操作而不会相互影响。
5.基本数据类型的比较是值的比较:
var a = '{}'
var b = '{}'
console.log(a === b) // 输出:true
6.基本类型的值在内存中占据固定大小的空间,被保存在栈内存中。(从一个变量向另一个变量复制基本类型的值,会创建这个值的一个副本);