JavaScript的“原型甘露”

来源:http://www.cnblogs.com/bluedoctor/archive/2016/09/18/5881019.html
-Advertisement-
Play Games

我們就把這種形式稱為“甘露模型”吧!其實,這種“甘露模型”的原型用法才是符合prototype概念的本意,才是的JavaScript原型的真諦! ...


今天跟朋友討論JS的面向對象編程問題,想起了原來曾經看過一篇文章,但是看過很久想不起來了,用了很多關鍵詞,終於用“悟透JavaScript  面向對象”這兩個關鍵詞找到了原文,原文地址:http://www.cnblogs.com/zhangshiwen/p/3627085.html

為防止以後難以看到這樣好的文章,特將原文中最有價值的“原型甘露”一段內容貼出來。

//語法甘露:
    var object =    //定義小寫的object基本類,用於實現最基礎的方法等
    {
        isA: function(aType)   //一個判斷類與類之間以及對象與類之間關係的基礎方法
        {
            var self = this;
            while(self)
            {
                if (self == aType)
                  return true;
                self = self.Type;
            };
            return false;
        }
    };
    
    function Class(aBaseClass, aClassDefine)    //創建類的函數,用於聲明類及繼承關係
    {
        function class_()   //創建類的臨時函數殼
        {
            this.Type = aBaseClass;    //我們給每一個類約定一個Type屬性,引用其繼承的類
            for(var member in aClassDefine)
                this[member] = aClassDefine[member];    //複製類的全部定義到當前創建的類
        };
        class_.prototype = aBaseClass;
        return new class_();
    };
    
    function New(aClass, aParams)   //創建對象的函數,用於任意類的對象創建
    {
        function new_()     //創建對象的臨時函數殼
        {
            this.Type = aClass;    //我們也給每一個對象約定一個Type屬性,據此可以訪問到對象所屬的類
            if (aClass.Create)
              aClass.Create.apply(this, aParams);   //我們約定所有類的構造函數都叫Create,這和DELPHI比較相似
        };
        new_.prototype = aClass;
        return new new_();
    };

    //語法甘露的應用效果:    
    var Person = Class(object,      //派生至object基本類
    {
        Create: function(name, age)
        {
            this.name = name;
            this.age = age;
        },
        SayHello: function()
        {
            alert("Hello, I'm " + this.name + ", " + this.age + " years old.");
        }
    });
    
    var Employee = Class(Person,    //派生至Person類,是不是和一般對象語言很相似?
    {
        Create: function(name, age, salary)
        {
            Person.Create.call(this, name, age);  //調用基類的構造函數
            this.salary = salary;
        },
        ShowMeTheMoney: function()
        {
            alert(this.name + " $" + this.salary);
        }
    });

    var BillGates = New(Person, ["Bill Gates", 53]);
    var SteveJobs = New(Employee, ["Steve Jobs", 53, 1234]);
    BillGates.SayHello();
    SteveJobs.SayHello();
    SteveJobs.ShowMeTheMoney();
    
    var LittleBill = New(BillGates.Type, ["Little Bill", 6]);   //根據BillGate的類型創建LittleBill
    LittleBill.SayHello();
    
    alert(BillGates.isA(Person));       //true
    alert(BillGates.isA(Employee));     //false
    alert(SteveJobs.isA(Person));       //true
    alert(Person.isA(Employee));        //false
    alert(Employee.isA(Person));        //true

  “語法甘露”不用太多,只要那麼一點點,就能改觀整個代碼的易讀性和流暢性,從而讓代碼顯得更優雅。有了這些語法甘露,JavaScript就很像一般對象語言了,寫起代碼了感覺也就爽多了!

    令人高興的是,受這些甘露滋養的JavaScript程式效率會更高。因為其原型對象里既沒有了毫無用處的那些對象級的成員,而且還不存在 constructor屬性體,少了與構造函數間的牽連,但依舊保持了方法的共用性。這讓JavaScript在追溯原型鏈和搜索屬性及方法時,少費許多 工夫啊。

    我們就把這種形式稱為“甘露模型”吧!其實,這種“甘露模型”的原型用法才是符合prototype概念的本意,才是的JavaScript原型的真諦!

    想必微軟那些設計AJAX架構的工程師看到這個甘露模型時,肯定後悔沒有早點把AJAX部門從美國搬到咱中國的觀音廟來,錯過了觀音菩薩的點化。 當然,我們也只能是在代碼的示例中,把Bill Gates當作對象玩玩,真要讓他放棄上帝轉而皈依我佛肯定是不容易的,機緣未到啊!如果哪天你在微軟新出的AJAX類庫中看到這種甘露模型,那才是真正 的緣分!

 


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

-Advertisement-
Play Games
更多相關文章
  • 題目鏈接 http://acm.hdu.edu.cn/showproblem.php?pid=5881 Problem Description Tea is good.Tea is life.Tea is everything.The balance of tea is a journey of p ...
  • 預處理程式 預處理程式語句使用井號(#)標記,這個符號必須是一行中的第一個非空格字元。 #define 語句(這種預定義通常也被稱為定義“巨集”): #define 語句的基本用途之一就是給符號名稱指定程式常量。 例如: #define Constant 1//預處理程式語句後面不要加分號(;) ,因 ...
  • 題目鏈接 http://acm.hdu.edu.cn/showproblem.php?pid=5884 Problem Description Recently, Bob has just learnt a naive sorting algorithm: merge sort. Now, Bob ...
  • 平時最常用到的UML圖包括:用例圖、類圖、序列圖、狀態圖。 用例圖 主要是描述系統具有的一個功能單元。通常包含角色和用例。角色通常表示為一個系統用戶,用例通常表示為系統具有的一個功能。通過用例圖我們可以輕易地識別到這個系統到底具備哪些功能單元。 下麵我舉個融投資的用例,有2種角色:投資人invest ...
  • 1.圖片間的來回切換用if{}else{}; <超鏈接方式的切換圖片(常用)>如:<a href="../images1/1-small.jpg" id="bnn"/>切換圖片</a><br/><img src="../images1/2-small.jpg" alt="" id="btt"/><s ...
  • 軟體版本: es:2.4.0 logstash:2.4.0 kibana:4.6.1 一、logstash安裝(收集、過濾日誌、構建索引) 1、下載:https://www.elastic.co/downloads/ 2、解壓 3、啟動 cd /Users/enniu1/Desktop/server ...
  • 1 package cn.reflex; 2 3 public interface PCI { 4 5 public void open(); 6 public void close(); 7 } //調用方法 package cn. reflex ; 2 3 import java.io.File ...
  • 一年不見,博客園都長草啦...... 前幾日剛入手新手機小米5,系統真心流暢呀。為啥要買小米5呢,因為要提高生產力呀,好好玩移動前端開發呀哈哈哈 那麼問題來了,要怎麼調試手機上的前端頁面呢? 很久很久以前,我的做法是:在PC上用Chrome移動模擬器調試好後,基本OK,再把相關文件傳到手機上,在真機 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...