javaScript設計模式 -- 靈活的javaScript語言

来源:https://www.cnblogs.com/z937741304/archive/2018/03/29/8671191.html
-Advertisement-
Play Games

因為好長時間的懶惰和懈怠,好久沒有更新文章了,從現在開始我會按時更新一些自己總結的一些知識,和研究的東西,希望能讓大家從我這裡學到一點點的知識。 本文參考了張榮銘的javascript設計模式一書,算是自己對看了文章的總結吧,如果你想學習設計模式,可以去購買一本,學習一下,寫的非常好。 javaSc ...


  因為好長時間的懶惰和懈怠,好久沒有更新文章了,從現在開始我會按時更新一些自己總結的一些知識,和研究的東西,希望能讓大家從我這裡學到一點點的知識。

  本文參考了張榮銘的javascript設計模式一書,算是自己對看了文章的總結吧,如果你想學習設計模式,可以去購買一本,學習一下,寫的非常好。

javaScript

 在我們的開發中,如果給了自己一些驗證姓名、郵箱、密碼的任務,按照下麵的寫法看

 1 //這樣寫就會污染到全局變數 都會掛載到window下
 2 function checkName() {
 3     //驗證姓名
 4 }
 5 function checkEmail() {
 6     //驗證郵箱
 7 }
 8 function checkPassword() {
 9     //驗證密碼
10 }

聲明的方式,還有另外一種

1 var checkName = function () {
2     //驗證姓名
3 };
4 var checkEmail = function () {
5     //驗證郵箱
6 };
7 var checkPassword = function () {
8     //驗證密碼
9 }

上面的兩種聲明方式都會產生好多全局變數,會影響其他人的使用,命名,所以我們可以把這些放到一個對象下麵

 1 var checkObject = {
 2     checkName : function () {
 3         //驗證姓名
 4     },
 5     checkEmail : function () {
 6         //驗證郵箱
 7     },
 8     checkPassword : function () {
 9         //驗證密碼
10     }
11 }
//還有另外一種添加方式
1
var checkObject = function(){} 2 checkObject.checkName = function(){} 3 checkObject.checkEmail = function(){} 4 checkObject.checkPassword = function(){}

 

雖然這樣可以滿足自己的需求,但是當別人想用你寫的對象的方法時候就麻煩了,因為這個對象不能複製一份

要實現複製一份看下麵的寫法

 1 var checkObject = function() {
 2     return {
 3         checkName : function(){
 4             //驗證姓名
 5         },
 6         checkEmail : function () {
 7             //驗證郵箱
 8         },
 9         checkPassword : function () {
10             //驗證密碼
11         }
12     }
13 };
14 15 var a = checkObject();
16 console.log(a);
17 a.checkEmail();

 

上面的方法雖然可以實現我們的功能,但是創建出來的對象a和對象checkObject沒有任何關係

我們對其進行改造一下

 1 var CheckObject = function () {
 2     this.checkName = function () {
 3         //驗證姓名
 4     };
 5     this.checkEmail = function () {
 6         //驗證郵箱
 7     };
 8     this.checkPassword = function () {
 9         //驗證密碼
10     }
11 };
12 13 var a = new CheckObject();
14 console.log(a);

上面這種方式已經實現了複製,但是我們每一次通過new關鍵字創建新對象的時候,新創建的對象都會經過this再執行一次,所以這些

新創建的對象都會有屬於自己的一套方法,然後有時候這麼做造成的性能消耗是非常奢侈的,我們需要處理一下,

將公有的方法放到構造函數的原型上

 1 var CheckObject = function () {
 2 };
 3  4 CheckObject.prototype.checkName = function () {
 5     //驗證姓名
 6 };
 7 CheckObject.prototype.checkEmail = function () {
 8     //驗證郵箱
 9 };
10 CheckObject.prototype.checkPassword = function () {
11     //驗證密碼
12 };

 

這樣創建對象實例的時候,找方法的時候如果自己本身沒有的話就會上原型上面一層一層的去找,就可以擁有方法了

 

上面的方法要把peototype寫好多遍,還可以寫成另外的一種形式

 1 CheckObject.prototype = {
 2     checkName : function(){
 3         //驗證姓名
 4     },
 5     checkEmail : function () {
 6         //驗證郵箱
 7     },
 8     checkPassword : function () {
 9         //驗證密碼
10     }
11 };
12 //這兩種方法不能混著用,要不然會覆蓋
13 //使用方法
14 15 var a = new CheckObject();
16 console.log(a);
17 a.checkEmail();

 

 

經常使用jQ都知道鏈式操作,其實實現方法很簡單就是將當前的對象作為函數的返回值return出去就行了,

鏈式操作

 1 var CheckObject = function () {
 2     this.checkName = function () {
 3         //驗證姓名
 4         return this;
 5     };
 6     this.checkEmail = function () {
 7         //驗證郵箱
 8         return this;
 9     };
10     this.checkPassword = function () {
11         //驗證密碼
12         return this;
13     }
14 };
15 var obj = new CheckObject();
16 obj.checkEmail().checkName().checkPassword();

函數的祖先

1 Function.prototype.checkEmail = function () {
2     console.log('驗證了郵箱');
3 };
4 //我們在他的原型上寫了一個這樣的方法之後,凡是用函數構造出來的對象都有了這個方法
5 var a = function () {
6 7 };
8 a.checkEmail();

 

如果習慣類的形式還可以這樣寫

1 var f = new Function(){};
2 f.checkEmail();

 

但是這樣做 在這裡是不允許的 因為污染了全局變數Function

 

可以用這種方法就可以避免了

 1 Function.prototype.addMethod = function (name,fn) {
 2     this[name] = fn;
 3 };
 4  5 var methods = function () {
 6  7 };
 8 methods.addMethod('checkName',function () {
 9     //驗證姓名
10     console.log('姓名');
11 });
12 methods.addMethod('checkEmail',function () {
13     //驗證郵箱
14     console.log('郵箱');
15 });
16 17 methods.checkName();
18 methods.checkEmail();

 

當然上面你嫌寫了好多個methods對象,你可以用鏈式方法

 1 Function.prototype.addMethod = function (name,fn) {
 2     this[name] = fn;
 3     return this;  //在這裡返回對象就可以了
 4 };
 5  6 var methods = function () {
 7  8 };
 9 methods.addMethod('checkName',function () {
10     //驗證姓名
11     console.log('姓名');
12 }).addMethod('checkEmail',function () {
13     //驗證郵箱
14     console.log('郵箱');
15 });
16 17 methods.checkName();
18 methods.checkEmail();

 

對於習慣類的人來說也可以這樣寫

當然習慣用類的人來說 也可以寫成類的形式

 1 Function.prototype.addMethod = function (name,fn) {
 2    this.prototype[name] = fn;
 3    return this;
 4 };
 5  6 var Methods = function(){};
 7  8 Methods.addMethod('checkName',function () {
 9    //驗證姓名
10    console.log('姓名');
11 }).addMethod('checkEmail',function () {
12    //驗證郵箱
13    console.log('郵箱');
14 });
15 16 var m = new Methods();
17 18 m.checkName();
19 m.checkEmail();

 

javaScript是一種靈活的語言,使用javascript可以編寫出更多的優雅的代碼藝術,我會在接下來的一段時間內將一些常用的設計模式的寫法,分享給大家,如果你能學到一些知識,我會非常開心的,文章如有不足之處,還望可以提醒。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JavaScript是一種最初由Netscape的LiveScript發展而來的面向對象的Web腳本語言,被ECMA國際定義為國際化標準——ECMAScript。JavaScript具有使用局限性。在Web方面,其必須與各種DOM技術結合才能發揮作用。因此,一些具有開拓創新精神的開發者們便開發出了各 ...
  • 自製了一個 nodejs 應用的腳手架。 大致就是以上這些,詳細的項目可以去 github 上 clone 下來查看。【傳送門】 另外,因為是在做自己博客站點的時候,突然想起來需要一個腳手架,所以才有了這個衍生項目,博客站點的項目還在開發中,稍微多了一點東西。 大致就是這些,詳細的可以去 githu ...
  • jquery.qrcode.min.js是一款可以生成二維碼的插件,使用前提是先引入jquery,因為jquery.qrcode.min.js依賴jquery。 基本用法 1.引入js 2.構建容器 3.生成二維碼 這樣,一個二維碼就生成了,通過掃二維碼,可以方便的訪問本博客。 拓展講解 (1)qr ...
  • <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> /*標簽名查找,名稱相同,格式相同*/ span{ color: coral; } /*id名查找,名稱不可重覆*/ ...
  • <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> /*固定在頁面某一位置*/ #a{ width: 20px; height: 20px; background-co ...
  • 2月,Github上第二受歡迎的項目是Flutter。Flutter的第一個測試版本是作為2018年世界移動通信大會的一部分而開始的。 Flutter是一款移動UI框架,旨在幫助開發人員在iOS和Android上創建高質量的原生界面。Flutter是免費和開源的,就像Android SDK一樣,並且 ...
  • <form.../>中method屬性指定了該表單是以哪種方式提交請求,有兩種方式:GET請求方式和POST請求方式,預設是GET請求方式。兩種方式的區別:get方式的請求是在瀏覽器地址欄中輸入訪問地址所發送的請求,即他是通過地址欄傳輸的。在地址欄中可以看到請求參數名和值。且get參數有長度限制,傳 ...
  • 寫在最前面:這篇博文是2篇文章組成,詳細介紹了Angularjs中的緩存以及緩存清理,文章由上海尚學堂轉載過來,歡迎大家閱讀和評論。轉載請註明出處,謝謝! 一個緩存就是一個組件,它可以透明地儲存數據,以便以後可以更快地服務於請求。多次重覆地獲取資源可能會導致數據重覆,消耗時間。因此緩存適用於變化性不 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...