应用类型对象拷贝

2017-05-09  本文已影响0人  虚玩玩TT

1.引用类型有哪些?非引用类型有哪些?

引用类型:对象,数组,函数,正则
非引用类型:数值,布尔值,字符串,null,undefined

2.如下代码输出什么?为什么?

var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);
console.log(obj1 = obj2);
console.log(obj 1== obj2);

结果:
false
obj1 和obj2 存于两个不同的位置,指针不同,所以不相等

{a:1, b:2}
赋值,将obj2中的内传递到obj1,输出此时obj1的结果

true
经过赋值,使得obj1的指针与obj2的指针相同

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)
console.log(bb)
console.log(cc)
console.log(dd)

结果:
1
将a的值赋值给aa后,改变a的值,但是aa是一个独立的存储空间,不受影响

2
同上

{ name: 'hello', age: 3}
var cc = c,将c的指针给了cc,改变c,cc也会变,d对'age'进行修改,也就是c中的'age'。

[1, 2, { name: 'hello', age:3 }]
数组d中的a,b,相当于var a' = a,var b' = b,这是一个独立的存储空间,不受a的影响

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)
console.log(c)

结果:
函数f1,f2没有写返回值,f1(a),f2(c),f1(c.age)只返回undefined不会产生结果。

1
f1(a)相当于function f1(n) {var n = a},对a的值不会造成影响

{name: 'jirengu', age: 3 }
运行f2(c)后,c = {name: 'jirengu', age: 3 },再运行f1(c.age) ,此时,相当于 n = c.age,对c.age不会产生影响。

5.过滤如下数组,只保留正数,直接在原数组上操作

var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
}
filter(arr)
console.log(arr)  //[3,1,2]

解答:

function filter(arr){
  for(var i = 0; i < arr.length; i++){
    if(arr[i] <= 0){
      arr.splice(i,1);
      filter(arr)
    }
  }
}

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]

解答:

function filter(arr){
  var arr2 = []
  for(var i = 0; i < arr.length; i++){
    if(arr[i] > 0){
      arr2.push(arr[i])
    }
  }
return arr2
}

7.写一个深拷贝函数,用两种方式实现

第一种:迭代

function copy(obj){
  var obj1 = {}
  for(var i in obj){
    if(typeof obj[i] === 'number' || typeof obj[i] === 'boolean' 
    || typeof obj[i] === 'string' || obj[i] === undefined || obj[i] === null ){
      obj1[i] = obj[i]
    } else{
        obj1[i] = copy(obj[i])
    }
   }
return obj1
}

第二种:JSON

function copy(obj){
  var obj1 = {}
  obj1 = JSON.parse(JSON.stringify(obj))
  return obj1
}
上一篇 下一篇

猜你喜欢

热点阅读