摘要:構造函數通常首字母大寫,用于區分普通函數。這種關系常被稱為原型鏈,它解釋了為何一個對象會擁有定義在其他對象中的屬性和方法。中所有的對象,都有一個屬性,指向實例對象的構造函數原型由于是個非標準屬性,因此只有和兩個瀏覽器支持,標準方法是。
從這篇文章開始,復習 MDN 中級教程 的內容了,在初級教程中,我和大家分享了一些比較簡單基礎的知識點,并放在我的 【Cute-JavaScript】系列文章中。
關于【Cute-JavaScript】:
一本可愛的JavaScript小書,內容分成三大部分:ES規范系列、JS基礎系列和面試題系列,目前我還在抓緊更新,喜歡的朋友可以 github 上Star一下呀,下面放一張首頁圖:
正文開始
本文是 重溫基礎 系列文章的第十五篇。
今日感受:耐心為人處世。
本章節復習的是JS中的關于對象還有原型等相關知識。
前置知識:
關于使用對象,可以先閱讀一下我的《12.使用對象》這篇文章。
下面也先重溫一點基礎。
1.概念對象是一個包含相關數據和方法的集合,由變量和方法組成,通常稱為對象的屬性和方法,比如:
let me = { name : "pingan", eat: function(){ console.log("eat eat eat!!!"); } }
其中,name就是me這個對象的一個屬性,eat就是me這個對象的一個方法。
訪問對象的屬性是這樣的:
me.name; // "pingan" me.eat(); // "eat eat eat!!!"
另外在訪問對象屬性時,有以下兩種方式:
let me = { name : "pingan", } // 點表示法 me.name; // me.name => "pingan" // 括號表示法 me["name"];// me.name => "pingan"
括號表示法中,必須是字符串。
我們常常這么設置對象的屬性:
let me = { name : "pingan", } // 點表示法 me.name = "leo"; // me => {name: "leo"} // 括號表示法 me["name"] = "leo";// me => {name: "leo"}2.簡單的面向對象介紹
這里簡單介紹下JavaScrip的面向對象編程OOP。
面向對象編程(Object Oriented Programming,OOP,面向對象程序設計)是一種計算機編程架構。OOP 的一條基本原則是計算機程序是由單個能夠起到子程序作用的單元或對象組合而成。 —— 百度百科
我們這里定義一個簡單的對象模型,比如我,我的身上可能有很多信息(姓名,年齡,身高等等),這時候我們可以將這些信息抽取出來,像這樣:
let leo = { name : "leo", age : 26, height : 180, }
這樣我們就將我的信息抽取成一個JS的對象了,但是這樣有個局限性,這樣定義的話,一次只能定義一個人,如果這時候,有一百個人,那么我們就需要定義一百個這樣的對象,顯然這是不可取的。
所以,這里就引入一個重要的函數——構造函數,將相同的特性封裝成通用的對象,實現定義一次,其他地方都可以使用,這也是OOP的核心思想:
// 傳入 name 參數使得可以定義任何人作為對象 function Person (name){ let me = {}; me.name = name; me.doSomething = function(){ console.log(me.name); } return me; }
創建一個函數“Person”,只要傳入不同的name即可得到不同的對象:
let leo = Person("leo"); leo.name; // "leo" let pingan = Person("pingan"); pingan.name; // "pingan"
但是似乎Person對象的定義,顯得不夠精簡,因為還要定義一個空對象來接收各個屬性和方法,幸好JavaScrip在構造函數中提供一個便捷的方法,我們將代碼改造下:
function Person (name){ this.name = name; this.doSomething = function(){ console.log(this.name); } }
對于this關鍵詞,即無論是該對象的哪個實例被構造函數創建,它的name屬性都是參數name的值,doSomething方法中使用的也是參數name。簡單理解就是用this指代了Person。
構造函數通常首字母大寫,用于區分普通函數。
接下來,通過new關鍵詞,使用前面創建的構造函數(使用構造函數也叫實例化):
let leo = new Person("leo"); leo.name; // "leo" let pingan = new Person("pingan"); pingan.name; // "pingan"
然后一個簡單的構造函數就寫好了,通常在開發的時候,可能會有很多的參數:
function Man(name, age, height, weight){ this.name = name; this.age = age + "歲"; this.HeightAndWeight = { height, weight }; this.doSomething = function (){ console.log(` ${this.name}: height:${this.HeightAndWeight.height}m, weight:${this.HeightAndWeight.weight}Kg!!` ); }; } let leo = new Man("leo",25,1.8,68); leo.doSomething(); // leo: height:1.8m, weight:68Kg!!3.JS中的原型 3.1理解原型
這里需要先了解一下Object和Function,這兩個函數都是JS的自帶函數,Object繼承自己,Function繼承自己,相互繼承對方,即Object和Function既是函數也是對象。
console.log(Function instanceof Object); // true console.log(Object instanceof Function); // true
Object 是 Function的實例,而Function是它自己的實例。
console.log(Function.prototype); // ? () { [native code] } console.log(Object.prototype); // Object
另外,只有通過Function創建的函數都是函數對象,其他都是普通對象(通常由Object創建):
function f1(){}; typeof f1 //"function" var o1 = new f1(); typeof o1 //"object" var o2 = {}; typeof o2 //"object"
理論知識:
JavaScript 常被描述為一種基于原型的語言 (prototype-based language)——每個對象擁有一個原型對象,對象以其原型為模板、從原型繼承方法和屬性。
原型對象也可能擁有原型,并從中繼承方法和屬性,一層一層、以此類推。這種關系常被稱為原型鏈 (prototype chain),它解釋了為何一個對象會擁有定義在其他對象中的屬性和方法。
準確地說,這些屬性和方法定義在Object的構造器函數(constructor functions)之上的prototype屬性上,而非對象實例本身。
個人理解:
JS中所有的函數對象,都有一個prototype屬性,對應當前對象的原型,但普通對象沒有,而prototype屬性下還有一個constructor,指向這個函數。
var p = {}; p.prototype; // undefined p instanceof Object; // true function f (){}; f.prototype; // object {constructor: ?} f === f.prototype.constructor; // true Object === Object.prototype.constructor; // true
JS中所有的對象,都有一個_proto_屬性,指向實例對象的構造函數原型(由于_proto_是個非標準屬性,因此只有ff和chrome兩個瀏覽器支持,標準方法是Object.getPrototypeOf())。
var p = new Person(); p._proto === Person.prototype; //true
修改原型:
經常我們也需要對原型進行修改:
function Person (name){ this.name = name; } // 添加一個getName方法 Person.prototype.getName = function(){ return "名字:" + this.name; } var p = new Person("leo"); p.getName(); // "名字:leo"
這里也說明了原型進行繼承,p繼承Person原型中新增的函數屬性getName。
3.2原型鏈概念:
javascript中,每個對象都會在內部生成一個 proto 屬性,當我們訪問一個對象屬性時,如果這個對象不存在就會去 proto 指向的對象里面找,一層一層找下去,直到找到為止,如果到了原型鏈頂端,還沒找到,則返回undefined,這就是javascript原型鏈的概念。
總結:
除了Object的prototype的原型是null,所有對象和原型都有自己的原型,對象的原型指向原型對象。
JS中所有的東西都是對象,所有的東西都由Object衍生而來, 即所有東西原型鏈的終點指向null。
更加詳細的介紹,可以查看下面參考文章。
參考文章:1.MDN JavaScript 對象入門
2.基于js中的原型
本部分內容到這結束
系列目錄:
【復習資料】ES6/ES7/ES8/ES9資料整理(個人整理)
【重溫基礎】1.語法和數據類型
【重溫基礎】2.流程控制和錯誤處理
【重溫基礎】3.循環和迭代
【重溫基礎】4.函數
【重溫基礎】5.表達式和運算符
【重溫基礎】6.數字
【重溫基礎】7.時間對象
【重溫基礎】8.字符串
【重溫基礎】9.正則表達式
【重溫基礎】10.數組
【重溫基礎】11.Map和Set對象
【重溫基礎】12.使用對象
【重溫基礎】13.迭代器和生成器
【重溫基礎】14.元編程
Author | 王平安 |
---|---|
pingan8787@qq.com | |
博 客 | www.pingan8787.com |
微 信 | pingan8787 |
每日文章推薦 | https://github.com/pingan8787... |
JS小冊 | js.pingan8787.com |
歡迎關注微信公眾號【前端自習課】每天早晨,與您一起學習一篇優秀的前端技術博文 .
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/101032.html
摘要:系列目錄復習資料資料整理個人整理重溫基礎篇重溫基礎對象介紹重溫基礎對象介紹重溫基礎介紹重溫基礎相等性判斷本章節復習的是中的關于閉包,這個小哥哥呀,看看。這里隨著閉包函數的結束,執行環境銷毀,變量回收。 本文是 重溫基礎 系列文章的第十九篇。今日感受:將混亂的事情找出之間的聯系,也是種能力。 系列目錄: 【復習資料】ES6/ES7/ES8/ES9資料整理(個人整理) 【重溫基礎】...
摘要:通常在轉換不同數據類型時,相等和不相等會遵循以下規則若有一個操作數是布爾值,則比較前會將布爾值轉換為數值轉為,轉為。 本文是 重溫基礎 系列文章的第十八篇。今日感受:優化自己的代碼,也是很愉快的事情。 系列目錄: 【復習資料】ES6/ES7/ES8/ES9資料整理(個人整理) 【重溫基礎】1-14篇 【重溫基礎】15.JS對象介紹 【重溫基礎】16.JSON對象介紹 【重溫基礎...
摘要:系列目錄復習資料資料整理個人整理重溫基礎篇重溫基礎對象介紹本章節復習的是中的關于對象相關知識。概念概念有三點全稱對象表示法。對象沒有分號,而對象有。序列化對象時,所有函數及原型成員都會被忽略,不體現在結果上。 本文是 重溫基礎 系列文章的第十六篇。今日感受:靜。 系列目錄: 【復習資料】ES6/ES7/ES8/ES9資料整理(個人整理) 【重溫基礎】1-14篇 【重溫基礎】15...
摘要:歡迎您的支持系列目錄復習資料資料整理個人整理重溫基礎篇重溫基礎對象介紹重溫基礎對象介紹重溫基礎介紹重溫基礎相等性判斷重溫基礎閉包重溫基礎事件本章節復習的是中的高階函數,可以提高我們的開發效率。 本文是 重溫基礎 系列文章的第二十一篇。 今日感受:想家。 本人自己整理的【Cute-JavaScript】資料,包含:【ES6/ES7/ES8/ES9】,【JavaScript基礎...
摘要:本文是重溫基礎系列文章的第二十篇。事件捕獲為截獲事件提供機會,然后實際的目標接收到事件,最后事件冒泡,對事件作出響應。事件處理事件處理,即響應某個事件。包括導致事件的元素事件類型等其他信息。 本文是 重溫基礎 系列文章的第二十篇。 這是第三個基礎系列的第一篇,歡迎持續關注呀! 重溫基礎 系列的【初級】和【中級】的文章,已經統一整理到我的【Cute-JavaScript】的Java...
閱讀 1703·2021-09-26 09:55
閱讀 3736·2021-09-22 15:31
閱讀 7448·2021-09-22 15:12
閱讀 2221·2021-09-22 10:02
閱讀 4693·2021-09-04 16:40
閱讀 1075·2019-08-30 15:55
閱讀 3032·2019-08-30 12:56
閱讀 1823·2019-08-30 12:44