1.引用类型有哪些?非引用类型有哪些
引用类型:数组,对象,函数,正则.引用类型是指实质内容保存在堆内存,栈内存只保存保存内容的堆内存的地址的类型.
非引用类型:数值,布尔值,undefined,null和字符串.非引用类型是指保存在栈内存的类型.
2.如下代码输出什么?为什么
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);//false
console.log(obj1 = obj2);
console.log(obj1 == obj2);//true
obj1和obj2都是引用类型,虽然对象内容相同,但是指向地址不同,仅仅是内容相同,所以第一个是false.第二个是赋值,把obj2的地址赋给obj1.第三个因为第二个地址赋值的关系,所以是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}
console.log(dd)//[1,2,{name:'hello',age:3}]
因为a和b是非引用类型,a和b在改变值后没有重新赋值,所以a和b的值没有改变,aa和bb的值也没有改变,aa是1,bb是2.c是对象,是引用类型,c.name='hello',d[2]['age']=3改变了c的堆内存的内容,值也就跟着变了,所以cc是{name:'hello',age:3}
.dd是数组,数组内容是a,b,c的内容,所以是[1,2,{name:'hello',age:3}]
4.如下代码输出什么? 为什么
var a = 1
var c = { name: 'jirengu', age: 2 }
function f1(n){
++n
}
function f2(obj){
++obj.age
}
f1(a)
f2(c)
f1(c.age)
console.log(a)//1
console.log(c)//{name:'jirengu',age:3}
执行f1()时a为参数,相当于在在函数内部有var n = a这句话,把a的值赋给n,对a是没有影响的,所以a还是1.最后在调用f1(c.age)的时候其实默认的也是通过给var n 赋值 3,这样即便进行了++n的操作,但也没有改变原始的c.age的值.
执行f2(c)时,因为c时引用类型,相当于把c的地址赋给了obj,所以obj.age+1后,堆内存内的内容也跟着改变了,c也就跟着改变了.
5.过滤如下数组,只保留正数,直接在原数组上操作
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
}
filter(arr)
console.log(arr) // [3,1,2]
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
for (var i=0;i
6.过滤如下数组,只保留正数,原数组不变,生成新数组
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr) // [3,1,0,-1,-3,2,-5]
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
var narr = [];
for (var i=0;i0){
narr.push(arr[i]);
}
}
return narr;
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr) // [3,1,0,-1,-3,2,-5]
7.写一个深拷贝函数,用两种方式实现
function copy(obj) {
var nobj = {};
for (var key in obj){
if (typeof obj[key] === "object"){
nobj[key] = copy(obj[key]);
}
else{
nobj[key] = obj[key];
}
}
return nobj;
}
function deepCopy(obj) {
var newObj = JSON.parse(JSON.stringify(obj));
return newObj;
}