JS中對象的深拷貝

ck_tools = {}

/**
 * 第一步:公用方法
 *
 */

//僞數組轉真數組
ck_tools.fArrToTArr = function(fArr){
    if(ck_tools.isFunction(Array.from)){
        return Array.from(fArr);//[...fArr]
    }else{
        return Array.prototype.slice.call(fArr);
    }
}

/**
 * 判讀是否是對象字面量(純對象)。對象字面量建立方式有{}、new Object()建立  
 */
ck_tools.isPlainObject = function(obj){
    var flag = false;
    if(!obj || typeof obj != 'object'){return flag;}
        if(ck_tools.isHasPro(obj.constructor.prototype,"isPrototypeOf")){
        flag = true;
    }
        return flag;
}

//判斷是不是數組
ck_tools.isArray = function(arr){
    if(ck_tools.isFunction(Array.isArray)){
        return Array.isArray(arr);
    }else{
        return Object.prototype.toString.call(arr) == '[object Array]';
    }
};
//對象屬性深拷貝
    ck_tools.extend = function(){
        //arguments不能在箭頭函數中使用
        if(arguments.length <= 0){return};
        var _self = this
        ,args = ck_tools.fArrToTArr(arguments);
        ,target = args[0]
        ck_tools.forEach(args,function(arg,i){
            if(i!=0){
                var keys = Object.keys(arg);
                ck_tools.forEach(keys,function(key,i){
                    var val = arg[key];
                    if(ck_tools.isPlainObject(val) || ck_tools.isArray(val)){
                        var newTarget = ck_tools.isArray(val)?[]:{};
                        //extend()返回給newTarget,再把newTarget值賦值給上一個目標對象 的key
                        target[key] = _self.extend(newTarget,val);
                    }else{
                        target[key] = val;
                    }
                });
            }
        });
        return target;
    }

 

//三、使用方法

var obj1 = {name:"ck",get:function(){alert("obj1的get()")}};
var obj2 = {age:18,arr:[1,2,3,[99,100]],p:{pc:"pc",ip:{ip:"ip",cpu:"cpu"}}}
var obj3 = ck_tools.extend({},obj1,obj2);

//結果以下圖
相關文章
相關標籤/搜索