typeof运算符
一、对于数字, typeof 返回number。比如typeof(1)//number
,对于非常规的数字类型而言,其结果返回的也是number。比如typeof(NaN)//number
二、对于字符串,typeof 返回string。比如typeof("123")//string
。
三、对于布尔类型,typeof 返回 boolean 。比如typeof(true)//boolean
。
四、对于对象、数组、null 返回 object 。比如typeof(window)
,typeof(document)
,typeof(null)
返回的值都是object。
五、对于函数类型,返回 function。比如:typeof(eval)
,typeof(Date)
返回的值都是function。
六、如果运算数是没有定义的(比如说不存在的变量、函数或者undefined),将返回undefined。比如:typeof(sss)
、typeof(undefined)
都返回undefined。
for…in和for…of
for…of遍历数组值,适用遍历数/数组对象/字符串/map/set等拥有迭代器的集合,但是不能遍历对象,与forEach()不同的是,它可以正确响应break、continue和return语句。for…of循环不支持普通对象,但如果你想迭代一个对象的属性,你可以用for…in循环或内建的Object.keys()方法(此方法不能枚举原型方法和属性)
for…in遍历的是数组索引,可以访问到数组原型上的方法method和name属性,适合拿来遍历对象键名
访问js对象的属性和方法的两种方式
访问对象属性有两种方式,点运算符( . )和中括号运算符( [] ),点运算符后会默认为标识符,是静态的,程序无法修改它。
中括号内的会默认为计算结果为字符串的表达式,是动态的,可存变量可修改。以下情况适用中括号:
1.属性名为非标识符
2.属性名是表达式
3.属性名是变量
var xx="ss"
var obj={}
obj.xx=11//{xx:11}
obj[xx]=12//{ss:12}
obj//{xx: 11, ss: 12}
访问对象方法只能通过点运算符:obj.fun=function(){}
深拷贝和浅拷贝
浅拷贝和深拷贝都只针对于引用数据类型,浅拷贝只复制指向某个对象的指针,而不复制对象本身,新旧对象还是共享同一块内存;但深拷贝会另外创造一个一模一样的对象,新对象跟原对象不共享内存,修改新对象不会改到原对象
浅拷贝
function simplecopy(obj1){
var obj2=Array.isAarray(obj1)?[]:{};
for(let shu in obj2){
obj2[shu]=obj1[shu]
}
return obj2
}
深拷贝
function deepcopy(obj1){
if(typeof obj1 == object){
var obj2=Array.isAarray(obj1)?[]:{};
for(let shu in obj2){
obj2[shu]=typeof shu==object?deepcody(obj1[shu]):obj1[shu];
}
}else{
var obj2=obj
}
return obj2
}
判断一个js对象是否为数组最准确的办法:Object.prototype.toString.call(arr) === ‘[object Array]’;