[原創]Javascript模擬“類”的綜合實現方式以及部分細節【截至ES6】

来源:http://www.cnblogs.com/bsfz/archive/2017/10/24/7720087.html
-Advertisement-
Play Games

最近幾個舊項目里使用的圖片編輯插件出現Bug, 經Review 後確定需要在其內外均做些改動,但是頭疼的發現部分頁面里的JavaScript 代碼被冗餘了NN次。部分新同事堆疊了大量的過程式的腳本塊(幾乎沒有利用面向對象封裝的概念-雖然面向對象也按需擇時),改起來挺累(而且幾個項目里各自不同)。本身... ...


前言   最近幾個舊項目里使用的圖片編輯插件出現Bug, 經Review 後確定需要在其內外均做些改動,但是頭疼的發現部分頁面里的JavaScript 代碼被冗餘了NN次。部分新同事堆疊了大量的過程式的腳本塊(幾乎沒有利用面向對象封裝的概念-雖然面向對象也按需擇時),改起來挺累(而且幾個項目里各自不同)。本身插件問題已經解決,但是就代碼這塊兒,針對面向對象的抽離封裝,反而想寫些東西。雖然沒有太多分享價值,自己也忘記不少,翻了下以前的各種代碼草稿,還是想儘量做些相對完整的記錄和分享。當然,文中若有不妥,歡迎指正。   正文   JavaScript 編程本身是不包含傳統“類”的概念的,這是不同於我們偏後端的一些強類型對象語言的(例如Java、C#等),而我們往往會利用funciton、 prototype 等關鍵字來實現一個類似“類”的原型模型(當然也包括各種繼承特性)。從而使得項目中的js更優美,更高效。(截至最新的ECMAScript6里也推出了更簡單的標準實現,後面會有相關演示)   【所有Demo 均可直接在我的github上下載(地址:https://github.com/tempbing/Javascript-ClassDemos) 】     一、首先模擬一個基礎版的“類”,常規方式,利用function 和 this 關鍵字。(這裡this關鍵字 代表調用的當前實例“對象”,不贅述(但初學者一定要深入理解,以前專業書里講了幾十頁)。 Tips:這裡稍微留意下代碼里的相關註釋     相關使用EG:     二、然後在這個基礎"類"上,額外附加更多特征,直接操作prototype演變成一個豐富的“類”(另:這裡有些小細節問題,註意下我在註釋里說到的部分細節):     相關使用EG - 讀取,這裡是一致:     相關使用EG - 更新,這裡則有些需要註意(代碼里也包含了詳細註釋提醒,這裡不做主要擴展):     還是用文字方式啰嗦提醒下: 當進行對象原型上的操作時(這裡特指使用prototype 附加操作),需要註意一個容易遺漏的關於記憶體堆棧的小細節。由於數組(這裡是Product原型附加的“tags”)屬於引用類型(或者說對象類型),如果用類似於C語言里的指針概念解釋則更形象,開闢的記憶體堆棧空間上,若為引用型,修改了該引用的具體值,那麼影響的是所有指向當前堆空間的變數。所以上面修改了product02的 tags值後,再查看product01的 tags值也是同樣發生了改變。當然,如果直接改了棧值(或者說指針標記),則等同於將當前指針指向了其他堆空間,屬於自身改變了,當然就不會影響到指向原來堆的其他標記(比如操作:product02.tags=['AutumnBing'])。 另:其實很多地方均有這樣的概念,容易入坑,這裡暫且不深入,註意這個小細節就好)     三、關於繼承,先利用prototype 原型鏈做個不是太推薦的簡單繼承(畢竟原型鏈的操作需要用到恰當地方,見demo):     相關使用EG:       四、更妥當的繼承方式,結合“call” 內部回調,操作上下文來實現,也更安全:     相關使用EG:       五、目前最新的ES6 中直接推出了專屬class概念,作為對象的模板,通過class關鍵字,可以直接定義封裝類 (個人認為更像是一個基於prototype的語法糖,但最起碼比ES5的Object.create() 半成品更佳)。     相關使用EG:       六、同樣,針對class,也擁有了新的繼承方式。增加extends和super,更加精簡直觀,這非常類似於JAVA/C#等強類型語言中的繼承方式:     相關使用EG:       結語 某些時候,我們對於是否面向對象的編程,會有一些實際考慮。但在代碼的模塊化、插件化開發里,需是毫無疑問的懷抱面向對象的理念。有些東西並不複雜,但延伸的概念和細節依然需要註意。以上本人結合現有知識,進行歸納和總結了關於“類”的一些相關實現方式,包括一些細節問題。如有不妥之處,歡迎各種方式的指正。所有demo,完整演示代碼,剛纔已全部提交到我的github上去了(地址:https://github.com/tempbing/Javascript-ClassDemos)。夜深了,準備睡了。   End.    
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • A代碼編輯器,線上模版編輯,仿開發工具編輯器,pdf線上預覽,文件轉換編碼B 集成代碼生成器 [正反雙向](單表、主表、明細表、樹形表,快速開發利器)+快速表單構建器 freemaker模版技術 ,0個代碼不用寫,生成完整的一個模塊,帶頁面、建表sql腳本,處理類,service等完整模塊C 集成阿 ...
  • 一、vue腳手架跨域問題 1.跨域問題 文件config/index.js 原始代碼: proxyTable修改如下: "參考資料" 2.遠程訪問問題 目的:寫好的項目希望在其他電腦上或手機上查看。 方法: 打開文件 config/index.js,在dev對象中添加一個屬性host,值為本機的ip ...
  • 最近火的不能再火的日誌框架就是ELK,其中E(Elasticsearch)表示日誌存儲,L(Logstash)表示日誌收集,K(kibana)表示日誌的UI界面,用來查詢和分析,而其中的L可以使用Fluentd來代替,並且以上架構都可以通過docker來進行快速的部署。 它們的工作流程 fluent ...
  • 本文帶來一個垂直方向的手風琴插件開發,可以定製的功能如下: 調用方法: 效果預覽: 效果預覽: 完整的手風琴插件代碼: html部分: 1 <!DOCTYPE html> 2 <html> 3 <head lang="en"> 4 <!--作者:ghostwu(吳華)--> 5 <meta char ...
  • 本文來源於多年的 JavaScript 編碼技術經驗,適合所有正在使用 JavaScript 編程的開發人員閱讀。本文的目的在於幫助大家更加熟練的運用 JavaScript 語言來進行開發工作。 ...
  • 最近自己在學習Vue.js,在看一些課程的時候可能Vue更新太塊了導致課程所講知識和現在Vue的版本不符,從而報錯,我會在以後的帖子持續更新Vue的變化與更新,大家也可以一起交流,共同監督學習! 1.關於Vue中$index獲取索引值已經取消,多用於多個元素的操作,像ul中的li,通過v-for來建 ...
  • 轉載博客園jiangxiaobo,最近需要接觸vue方面的東西. 方法與事件處理器 方法處理器 可以用 v-on 指令監聽 DOM 事件: 我們綁定了一個單擊事件處理器到一個方法 greet。下麵在 Vue 實例中定義這個方法: 內聯語句處理器 除了直接綁定到一個方法,也可以用內聯 JavaScri ...
  • 棧(stack)和堆(heap) stack為自動分配的記憶體空間,它由系統自動釋放;而heap則是動態分配的記憶體,大小不定也不會自動釋放。 基本類型和引用類型 基本類型:存放在棧記憶體中的簡單數據段,數據大小確定,記憶體空間大小可以分配。 基本數據類型有Undefined、Null、Boolean、Nu ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...