饥人谷技术博客

引用类型对象拷贝

2017-09-30  本文已影响15人  1a659520c6fc

基本类型有哪些?引用类型有哪些2.如下代码输出什么?为什么

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

基本类型:Number、String、Boolean、Null、Undefined
引用类型:object

obj1、obj2中存的内存地址不一样所以第一个输出 false
obj1 = obj2是将obj2的内存地址赋值给obj1所以输出{a:1,b:2}
此时内存地址一样输出true

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

  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)

a、b是基本类型 所以
console.log(aa) 输出1
console.log(bb) 输出2
c、d是引用类型所以cc、dd内存的是内存地址,c.name = 'hello'改变了堆内存的变量name所以console.log(cc)输出:{ name: 'hello', age: 2 },d[2]['age'] = 3改变了d指向的堆内存中索引为2的age的值为3所以输出:[1,2,{name: 'hello', age: 3}]

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

  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)

函数作用域内的变量不会污染全局变量又是基本类型
console.log(a) 输出1
f2(c)c指向的堆内存中age变为3所以输出{ name: 'jirengu', age: 3 }

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

  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 -= 1
        }
    }
  }
  filter(arr)
  arr
  (3) [3, 1, 2]

过滤如下数组,只保留正数,原数组不变,生成新数组

  var arr = [3,1,0,-1,-3,2,-5]
  function filter(arr){
     var result = []
     for(var i = 0; i < arr.length; i++){
        if(arr[i] > 0){
           result.push(arr[i])
        }
     }
     return result 
    }
  undefined
  var arr2 = filter(arr)
  undefined
  arr2
  (3) [3, 1, 2]

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

  function copy(obj){
      var newObj = {}
      for(var key in obj){
          if(obj.hasOwnProperty(key)){
              if(typeof obj[key] === 'number' || typeof obj[key] === 'string' || 
                  typeof obj[key] === 'boolean' || typeof obj[key] === undefined 
                  || obj[key] === null){
                  newObj[key] = obj[key]
              }else{
                   newObj[key] = cop(obj[key])
              }
          }
      }
      return newObj
  }

  var obj1 = copy(obj)

JSON方法

  function copy(obj) {
      var newObj = JSON.parse(JSON.stringify(obj));
      return newObj;
  }

  var obj1 = copy(obj)
上一篇 下一篇

猜你喜欢

热点阅读