本文主要為大家帶來一篇基於物件合併功能的實作範例。小編覺得蠻不錯的,現在就分享給大家,也給大家做個參考。一起跟著小編過來看看吧,希望能幫助大家。
前言
jQuery 中的$.extend() 是經常使用到工具函數,多用於合併參數(物件),具體用法在這裡不過多贅述,可透過傳參控制合併過程中是否使用深度拷貝;而ES2015中新增的Object.assign()方法,也可以實現物件的合併,不過合併過程中使用的是淺拷貝;本文參考了jQuery的extend方法的來源碼,將自己實作物件合併,即將多個物件的屬性複製到目標物件上,若有相同的屬性,後面的物件覆寫前面的。
淺拷貝的方式實現物件合併
之前的一篇部落格文章 有專門介紹物件和陣列的深淺拷貝,不了解的童鞋請移步。先看實作再解釋
function extend() { //extend 浅拷贝实现 var name,options,copy, length = arguments.length, i = 1, target = arguments[0] || {}; //取目标对象 if(['object','function'].indexOf(typeof target) <p>想法如下:</p><p>1、預設取第一個參數為目標對象,若第一個參數非物件資料類型,則賦值為空物件</p><p>2、遍歷剩下的參數(來源物件),將來源物件的屬性複製到目標物件上。 </p><p>3、返回目標物件為合併的結果</p><p>在第二步驟中沒有對來源物件的屬性值進行判斷,所有的全部使用'=' 賦值,所以當來源物件的屬性值為物件屬性時,複製的只是引用值,也就是為淺拷貝的方式,在測試結果中可以看出test 和test2 的b 屬性的屬性值,使用的是同一個對象,會互相影響。知道了這些之後,如何實現合併時的深拷貝也應該有想法了。 </p><p>深度拷貝的方式實作物件合併</p><p>需要在複製來源物件屬性值時,判斷值的類型,如果是物件資料類型,則遞迴呼叫extend函數。則可以實習深拷貝方式的物件合併,實現如下:</p><pre class="brush:php;toolbar:false">function extend() { //extend 深拷贝实现 var name,options,src,copy, deep = false, //是否深拷贝 默认为false length = arguments.length, i = 1, target = arguments[0] || {}; //如果第一个参数为boolean类型,赋值给deep if(typeof target == 'boolean'){ deep = arguments[0]; target = arguments[i] || {}; //目标对象顺延 i++; } //如果target不是对象数据类型的话 target赋值为 {} if(['object','function'].indexOf(typeof target) <p>1、參數判斷,若第一個參數為布林類型,則取為控制是否深度拷貝的參數deep , deep 預設為false;同時目標元素會是第二個參數 </p><p>2、複製屬性值時,要判斷deep參數和屬性值的類型; 若deep為true 且屬性值為物件類型則遞歸呼叫extend函數, 否則直接賦值</p><p>3、需要區分數組和'物件' ,來給目標物件的屬性賦值不同的初始值。如果都是{} 的話,陣列型別的屬性值複製到目標元素上會變成{'0':xx , '1' : xx ...}</p><p>結語</p><p>一直都是在直接使用$.extend(),好用但是不是很清楚其中的實現,自己*,也許實現上還有不嚴謹的地方,但是覺得收穫還是不錯的。 </p><p>相關推薦:<br></p><p><a href="http://www.php.cn/js-tutorial-380068.html" target="_self">實作物件合併功能的方法</a></p>#
以上是關於物件合併功能的實現詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript在現實世界中的應用包括前端和後端開發。 1)通過構建TODO列表應用展示前端應用,涉及DOM操作和事件處理。 2)通過Node.js和Express構建RESTfulAPI展示後端應用。

JavaScript在Web開發中的主要用途包括客戶端交互、表單驗證和異步通信。 1)通過DOM操作實現動態內容更新和用戶交互;2)在用戶提交數據前進行客戶端驗證,提高用戶體驗;3)通過AJAX技術實現與服務器的無刷新通信。

理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

Python和JavaScript在社區、庫和資源方面的對比各有優劣。 1)Python社區友好,適合初學者,但前端開發資源不如JavaScript豐富。 2)Python在數據科學和機器學習庫方面強大,JavaScript則在前端開發庫和框架上更勝一籌。 3)兩者的學習資源都豐富,但Python適合從官方文檔開始,JavaScript則以MDNWebDocs為佳。選擇應基於項目需求和個人興趣。

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

SublimeText3漢化版
中文版,非常好用

Dreamweaver Mac版
視覺化網頁開發工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器