javascript淺層克隆、深度克隆對比及實例解析
這篇文章主要介紹了javascript淺層克隆、深度克隆對比及實例解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
1、淺層克隆, (引用值改變, 兩個都一起變)
var obj = { name : 'xiaoming', age : 12, children : ['mimi','lili','rokey'] } var obj2 = {}; function clone(origin, target) { var target = target || {}; for(var prop in origin) { target[prop] = origin[prop]; } return target; } clone(obj, obj2);
2、深度克隆 (只考慮數(shù)組和對象)
(1)判斷是不是原始值
?。?)判斷是數(shù)組還是對象 Object.prototype.toString.call([]) = '[object Array]' Object.prototype.toString.call({}) = '[object Object]'
(3)建立相應(yīng)的數(shù)組和對象
(4)遞歸
function deepClone(origin, target) { var target = target || {}, toStr = Object.prototype.toString, arrStr = '[object Array]'; for(var prop in origin) { if(origin.hasOwnProperty(prop)) { //判斷是不是對象自帶的屬性 if(origin[prop] !== 'null' && typeof(origin[prop]) == 'object') { if(toStr.call(origin[prop]) == arrStr) { target[prop] = []; }else { target[prop] = {}; } deepClone(origin[prop], target[prop]); }else { target[prop] = origin[prop]; } } } return target; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js操作css屬性實現(xiàn)div層展開關(guān)閉效果的方法
這篇文章主要介紹了js操作css屬性實現(xiàn)div層展開關(guān)閉效果的方法,涉及javaScript操作css樣式實現(xiàn)div彈出層的效果,非常具有實用價值,需要的朋友可以參考下2015-05-05微信小程序?qū)崿F(xiàn)form表單本地儲存數(shù)據(jù)
這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)form表單本地儲存數(shù)據(jù),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-06-06js判斷輸入是否中文,數(shù)字,身份證等等js函數(shù)集合
收集的比較多,建議大家查找搜尋,常用的js判斷函數(shù)2008-09-09用Golang運行JavaScript的實現(xiàn)示例
這篇文章主要介紹了用Golang運行JavaScript的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11