1.引用类型有哪些?非引用类型有哪些
基本类型值(Number、Boolean、string、null和undefined):指的是保存在栈内存中的简单数据段;
引用类型值(对象、数组、函数、正则):指的是那些保存在堆内存中的对象,变量中保存的实际上只是一个指针,这个指针执行内存中的另一个位置,由该位置保存对象
2.如下代码输出什么?为什么
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);输出//false;因为是两个不同的指针,分别指向不同的堆内的对象
console.log(obj1 = obj2);//输出Object {a: 1, b: 2};将obj2赋值给obj1;
console.log(obj1 == obj2);//输出true;引用类型的赋值是对象引用,指向同一个地址
3.如下代码输出什么? 为什么
var a = 1
var b = 2
var c = { name: '饥人谷', age: 2 }
var d = [a, b, c]
var aa = a
var bb = b
var cc = c
var dd = d
a = 11
b = 22
c.name = 'hello'
d[2]['age'] = 3
console.log(aa) //1;
原因:基本类型的复制,会在变量对象上创建一个新值,然后把该值复制到为新值配置的位置上,该值只是一个副本,可以参与任何操作不受影响。
console.log(bb) //2 ;
原因同上
console.log(cc) // { name: 'hello', age: 3 } ;
原因:引用类型的复制,同样会在栈中开辟新的空间,是一个副本,但是这个副本是一个指针,这个指针指向同一个对象。因此改变任何一个变量就会影响另个一个变量。操作c.name='hello'改变了对象c的 name为hello;变量d中d[2]的指针指向对象c,操作d[2]['age'],改变了对象c的age为3
console.log(dd) //[1,2,{ name: 'hello', age: 3 }]
原因:d 中保存的是基本类型a =1,基本类型b=2,
引用类型c ,根据之前描述的基本类型赋值,引用类型赋值的特点,a ,b不变,操作c.name = 'hello'
d[2]['age'] = 3,均影像了对象c;
4.如下代码输出什么? 为什么
var a = 1
var c = { name: 'jirengu', age: 2 }
function f1(n){
++n
}
function f2(obj){
++obj.age
}
f1(a); //没有返回值,同时全局变量a 没赋值
f2(c); // 没有返回值,但是改变了引用类型c的age为3
f1(c.age) //没有返回值,同时全局变量a 没赋值
console.log(a) //1;由于每次操作没给a 赋值,所以a不变。
console.log(c) // { name: 'jirengu', age: 3 } //操作f2(c)改变了age为3;
5.过滤如下数组,只保留正数,直接在原数组上操作
var arr = [3,1,0,-1,-3,2,-5];
function filter(arr){
for(var i=0;i<arr.length;i++){
if(arr[i]<=0){
arr.splice(i,1)
i--;
}
}
}
filter(arr)
console.log(arr) // [3,1,2]
6.过滤如下数组,只保留正数,原数组不变,生成新数组
var arr = [3,1,0,-1,-3,2,-5]
方法一;
function filter(arr){
var arr2 = arr.filter(function(item,index,array){//ie8以上
return (item > 0)
})
return arr2;
}
方法二;
function filter(arr){
var arr2=[];
for(var i=0;i<arr.length;i++){
if(arr[i]>0){
arr2.push(arr[i])
}
}
return arr2
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr) // [3,1,0,-1,-2,2,-5]
7.写一个深拷贝函数,用两种方式实现
深拷贝理解:深复制不是简单的复制引用,而是在堆中重新分配内存,并且把源对象实例的所有属性都进行新建复制,复制后的对象与原来的对象是完全隔离的。
参考网址http://www.cnblogs.com/tracylin/p/5346314.html
方法一
var array = {
age:25,
friends:{
name:"andy",
age:16
}
}
function deepCopy(oldObj){
var newObj = {};
for(key in oldObj){
if(typeof oldObj[key]==="object" && oldObj[key]!= null){
newObj[key]=deepCopy(oldObj[key])
}else{
newObj[key]=oldObj[key]
}
}
return newObj;
}
var obj2 = deepCopy(array);
方法二
var source = {
name:"source",
child:{
name:"child"
}
}
var target = JSON.parse(JSON.stringify(source));