分类:
1.原始类型:数值、字符串、布尔、null、undefined
2.引用类型:对象(Array、Date、Math。。)
原始类型与引用类型三种情况下的对比:
1.赋值
//原始类型赋值
let str1 = "hello";
let str2 = str1;
str1 = "world";
console.log(str1);//world
console.log(str2);//hello
//引用类型赋值
let stu1 = {name:"xiaoming"};
let stu2 = stu1;
stu1.name = "xiaohong";
console.log(stu1.name);//xiaohong
console.log(stu2.name);//xiaohong
原始类型赋【值】,引用类型赋【引用】
2.比较
//原始类型的比较 ===
let str1 ="hello"
let str2 ="hello"
console.log(str1 === str2)//true
//引用类型的比较
let stu1 = {name:"xiaoming"}
let stu2 = {name:"xiaoming"}
let stu3 = stu1
console.log(stu1 === stu2)//false
console.log(stu1 === stu3)//true
原始类型比较的是值是否相等,引用类型比较的是【引用】是否指向同一个对象。
4.函数传参
//原始类型传参
function fun(num){
num = 100
}
let n = 10
fun(n)
console.log(n)//10
//引用类型传参
function fun1(arr){
arr.push(10)
}
let a = [1,2,3]
fun1(a)
console.lgo(a)//[1,2,3,10]
原始类型作为参数,函数内的操作不影响实参的值。引用类型作为参数,函数内的操作会影响实参的值。