javascript對象原型及構造函數介紹

来源:http://www.cnblogs.com/smallTao/archive/2016/06/06/5562881.html
-Advertisement-
Play Games

對象是js中的一種基本的數據類型,除了可以給自身附屬性外,javascript對象還可以從一個稱為原型的對象繼承屬性。這種“原型式繼承”是javascript的核心特征。 在javascript中,創建一個對象通常可以有三個方法,對象直接量,關鍵字new和Object.create()函數。接下來會 ...


     對象是js中的一種基本的數據類型,除了可以給自身附屬性外,javascript對象還可以從一個稱為原型的對象繼承屬性。這種“原型式繼承”是javascript的核心特征。

     在javascript中,創建一個對象通常可以有三個方法,對象直接量,關鍵字new和Object.create()函數。接下來會對這些技術稍作講述,然後引出原型及構造函數。

     一:對象直接量

      對象直接量是一個表達式,這個表達式的每次運算都創建並初始化一個新的對象。下麵有一些例子:

        var o = {};     //這個方法和var o =new Object();一樣。

        var object = {'x':1,'y':2};

        var word = {'word':'hello',"sayHello":function(){}};

      二:通過new創建對象

      new運算符創建並初始化一個對象,往往後面跟著一個構造函數的調用,就像這樣:

        var o = new Object(); //創建一個空對象 跟{}一樣

        var a = new Array();

        var d = new Date();

除了一些內置的構造函數以外,也可以自定義構造函數用來初始化新對象。

    function A(){     //構建的構造函數一樣要求首字母大寫的習慣

    };

    var a = new A();  

    三. Object.create()

    ECMAScript5定義了一個名為Object.create()的方法,它創建了一個新對象,其中第一個參數是這個對象的原型。諸如:

    var o = Object.create({'x':1,'y':2});  //o繼承了屬性x,y

    var o2 = Object.create(Object.prototype); //這種方法和{}及new Object()一樣

 但是這個有個特殊的存在,var o1 = Object.create(null);  //o1將不繼承任何屬性,null不存在任何原型對象。

進入正題

   OK,到現在介紹完了對象的創建,我們再簡單解釋下原型。每一個javascript對象(null除外)都和另一個對象相關聯,“另一個”對象就是我們熟知的原型,每一個對象都從原型繼承屬性。

      所有通過對象直接量創建的對象都具有同一個原型對象(Object.prototype)。通過關鍵字new和構造函數調用創建的對象的原型就是構造函數的prototype屬性的值。就好像通過new Array ( )創建的對象的原型就是Array.prototype , 通過new Function()創建的對象的原型就是Function.prototype。通過Object.create(xx)創建的對象的原型就是其傳進去的參數。

     沒有原型的對象不多,null及Object.prototype都是,他們不繼承屬性。其他的原型對象都是普通對象,普通對象都具有原型。所有的構造函數都具有一個繼承自Object.prototype的原型。舉個例子,var f = new Function(); f對象的屬性繼承了Function.prototype,而Function.prototype又繼承了Object.prototype,這一系列鏈接的原型對象就是所謂的“原型鏈”(prototype chain)。一個對象的__proto__ 屬性和自己的內部屬性[[Prototype]]指向一個相同的值 (通常稱這個值為原型),原型的值可以是一個對象值也可以是null(比如說Object.prototype.__proto__的值就是null).

    舉個例子:

    s是String構造的實例,它指向String的原型(String.prototype),String的原型指向Object.prototype,Object.prototype的原型指向null。

   接下來談談構造函數 

    儘管構造函數不像原型那樣基礎,但構造函數是類的“外在表現”。構造函數的名字通常用作類名。常見的內置構造函數有Object,Array,String,Function,Number等,任何js的函數都可以用來作為構造函數,並且調用構造函數是需要用到一個prototype屬性的。這個屬性是一個對象,這個對象包含唯一一個不可枚舉屬性constructor,constructor屬性的值是一個函數。

    而且,例子中可以看到構造函數的原型中的constructor屬性等於這個構造函數本身,這也就意味著對象通常繼承的constructor均指代它們的構造函數。

接下來會有一個問題。

Function,String構造函數均是對象,它們的原型指向都是對象原型,所以它們都是Object的實例,那麼,String,Function這些構造函數和Function有什麼關係呢?Object instanceof Function的結果是什麼呢?

事實證明:

解釋如下:
   javascript里一切都可以當作對象來看待,構造函數本身也是對象,它們都是由Function實例化來的,它們(指的String等本身,而不是它們的原型對象)的原型指向Function.prototype.所以,它們也都是Function的實例對象。

 

本文實屬個人理解js的原型部分,如果有什麼錯誤的地方,歡迎指出,拍磚~


歡迎關註我的訂閱號,每周均有本人嘔心瀝血之作,請多多交流,請教~~~純屬技術交流,廣告黨就免啦~~謝絕不走。。


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

-Advertisement-
Play Games
更多相關文章
  • 通過一條命令用Npm安裝gulp-htmlmin: 安裝完畢後,打開gulpfile.js文件,我們裡面編寫一個task用來專門壓縮html,並對html進行一系列的處理: 我們看到task裡面有個設置選項,分別介紹一下他們的屬性的作用: 1.collapseWhitespace:從字面意思應該可以 ...
  • script、image、iframe的src都不受同源策略的影響。所以我們可以藉助這一特點,實現跨域。如前面所介紹的JSONP跨域,以及燈標(Beacons)。該篇隨筆主要闡述iframe結合一些技術,實現跨域請求。1、iframe+window.name;2、iframe+location.ha... ...
  • 今天我們來看看css組件效果以及其中比較重要的類,這些類都不難,關鍵要熟練掌握,搭配使用,靈活運用。關於前兩篇中,css樣式和佈局的文章,大家可以在首頁進行閱讀。http://www.cnblogs.com/jtjds/ 一:導航組件 自己做了個導航,目前只有一級菜單,下一篇文章中,將給出二級菜單, ...
  • 將函數與其參數的一個子集綁定的技術稱為函數柯里化(curring),以邏輯學家Haskell curry的名字命名。 比起顯式的封閉函數,函數柯里化是一種簡潔的、使用更少引用來實現函數委托的技術。bind方法提供了一種更簡單的實現,結構更簡單,但對於不瞭解bind方法的人理解起來可能有一點難度。 ...
  • 在我們平時寫代碼的時候沒有沒有掌握一些CSS技巧呢? 今天給大家分享一個《CSS 高級技巧彙總讓你的代碼簡潔高效》。大家務必掌握這些小技巧,會讓你非常高效率的寫出網頁的。 ◆使用 :not() 在菜單上應用/取消應用邊框 先給每一個菜單項添加邊框 ……然後再除去最後一個元素…… ……可以直接使用 : ...
  • 如果我們需要向組件傳遞參數,可以使用 this.props 對象,實例如下: <body> <div id="example"></div> <script type="text/babel"> var HelloMessage = React.createClass({ render: funct ...
  • javascript之基本包裝類型 學習要點: 基本包裝類型概述 Boolean類型 Number類型 String類型 一、基本包裝類型概述 為了便於操作基本類型值,提供了3種特殊的引用類型:Boolean,Number和String。 二、Boolean類型 new Boolean(value) ...
  • 至今HTML5中國已經為大家分享過幾百種基於 CSS3 的Loading載入動畫,效果酷炫代碼簡潔,非常值得學習借鑒;今天就先給大家分享兩個常用的CSS3的Loading的案例。 第一種效果: HTML部分 CSS3部分 第二種效果: HTML部分 CSS3部分 上面這兩個都是大家常用的載入效果,下 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...