Maison  >  Article  >  interface Web  >  Implémenter la copie profonde et la copie superficielle dans jquery

Implémenter la copie profonde et la copie superficielle dans jquery

一个新手
一个新手original
2017-09-22 09:43:281710parcourir


var toString = [].toString,
    hasOwn = Object.prototype.hasOwnProperty;var types = {    
    '[object Boolean]':'bool',    
    '[object Number]' : 'number',  
        '[object String]' : 'string',  
    '[object Object]':'object',    
    '[object Array]':'array',    
    '[object Function]':'function',    
    '[object Date]' : 'date', 
            '[object RegExp]' : 'regExp',  
};var type = function(obj){
    return obj === null ? String(obj) : types[toString.call(obj)] || 'object'; 
};var isWindow = function(obj){
    return obj && typeof obj === 'object' && 'setInterval' in obj;
};var isArray = Array.isArray || function(obj){
    return type(obj) === 'array';
};var isPlainObject = function(obj){
    if(!obj || type(obj) !== 'object' || isWindow(obj) || obj.nodeType){        
    return false;
    }    
    try{        
    if(obj.constructor && !hasOwn.call(obj, 'constructor') 
            && !hasOwn.call(obj.constructor.prototype, 'isPrototypeOf')){            
            return false;
        }
    }catch(e){        
    return false
    }    
    var key;    for(key in obj){}    return key === undefined || hasOwn.call(obj, key)
}function extend(deep, target, ref){
    var name, value, src, copy, clone, copyIsArray;    for(name in ref){
        src = target[name];
        copy = ref[name];        
        if(target === copy){            
        continue;
        }        
        if(deep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))){            
        if(copyIsArray){
                clone = src && isArray(src) ? src : [];
            }else{
                clone = src && isPlainObject(src) ? src : {}; 
            }
            target[name] = extend(deep,clone,copy);
        }else{
            target[name] = copy;
        }
    }    return target;
}function extend2(target, ref){
    var name, value;    
    for(name in ref){
        value = ref[name];        
        if(value !== undefined){
            target[name] = value;
        }
    }    return target;
}

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn