摘要:一面向對象編程面向對象編程是一種抽象方式創(chuàng)建模型的編程方式。繼承我們實現(xiàn)一個子類,繼承汽車類將類的屬性和方法賦值給繼承汽車類的原型鏈創(chuàng)建子類實例以上是中的面向對象編程的簡單介紹,如有錯誤,歡迎指出。
一.面向對象編程
面向對象編程(OOP--Object Oriented Programming)是一種抽象方式創(chuàng)建模型的編程方式。繼承,封裝,多態(tài)是OOP的三大基本特征。許多主流編程語言都支持OOP。例如Java,c++中通過new調用‘類’來創(chuàng)造實例,但是學習了JS的同學知道JS中沒有類的概念,那么JS怎么實現(xiàn)面向對象編程的呢?
JS實現(xiàn)OOP是通過原型鏈實現(xiàn)的,原型鏈的概念在這里不詳細講述,大家記住一個例子即可:
function._proto_ ==== Function.prototype
JS也通過new來創(chuàng)建實例,但是后面調用的不是類,而是構造函數。
下面我們通過封裝繼承一個‘類’的例子來詳細闡述。
二.ES5實現(xiàn)封裝 繼承一個類
1.封裝
我們知道寶馬,奔馳,奧迪等都是汽車,汽車這個概念就是一個類,抽象出來代表了日常生活中的許多具體事物。
//汽車 構造函數 function Car (name,color){ this.name = name; this.color = color; }
2.prototype模式
汽車的屬性有很多,不僅僅是名字和顏色,如果全部寫在構造函數里,創(chuàng)建實例時再去一一地調用太過于麻煩,于是JS規(guī)定了一個prototype模式,每個構造函數都有一個prototype屬性指向原型,“類”里面一些共有的屬性可以放在原型里面。例如汽車類的車型,動能方式等屬性都是共有屬性可以放在原型里。
Car.prototype.type = "car"; Car.prototype.getType = function () { return this.type; }; Car.prototype.setType = function (newType) { this.type = newType; return newType; }; Car.prototype.getName = function () { return this.name; }; Car.prototype.setName = function (newName) { this.name = newName; return newName; };
3.new關鍵字
JS中通過new關鍵字創(chuàng)建實例。
var car1 = new Car("寶馬","red"); console.log(car1.type) // "car"
這里,我們思考一個問題:使用new創(chuàng)建實例,new到底做了些什么呢?
使用new創(chuàng)建實例,實際上是幫助我們減少了四行代碼:
1.new創(chuàng)建了臨時對象,可以使用this訪問到臨時對象
2.new也幫我們return了這個臨時對象
3.new指定了原型的名字--prototype
4.new創(chuàng)建實例,自動綁定原型。
car1._proto_ === Car.prototype
4.繼承
我們實現(xiàn)一個‘子類’,繼承‘汽車類’
function SUV ( price) { Car.call(this, "suv"); // 將 Car 類的屬性和方法賦值給 SUV this.price = price; }
SUV.prototype = new Car("suv");// 繼承汽車類的原型鏈 SUV.prototype.getPrice = function () { return this.price; }; SUV.prototype.setPrice = function (newPrice) { this.price = newPrice; return newPrice; };
//創(chuàng)建子類實例 var suv1 = new SUV(1000); console.log(suv1.getPrice());//1000
以上是JS中的面向對象編程的簡單介紹,如有錯誤,歡迎指出。
參考鏈接:
Javascript繼承機制的設計思想--阮一峰
JS中的new到底是干什么的?---方應杭
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/107042.html
摘要:很多情況下,通常一個人類,即創(chuàng)建了一個具體的對象。對象就是數據,對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍圖或原型。在中,對象通過對類的實體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...
摘要:很多情況下,通常一個人類,即創(chuàng)建了一個具體的對象。對象就是數據,對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍圖或原型。在中,對象通過對類的實體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...
摘要:很多情況下,通常一個人類,即創(chuàng)建了一個具體的對象。對象就是數據,對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍圖或原型。在中,對象通過對類的實體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...
摘要:一面向對象編程簡介定義,簡稱,是一種程序設計思想。好處維護簡單模塊化是面向對象編程中的一個特征。可擴充性面向對象編程從本質上支持擴充性。 一、面向對象編程簡介 1.定義: Object Oriented Programming,簡稱OOP,是一種程序設計思想。OOP把對象作為程序的基本單元,一個對象包含了數據和操作數據的函數。 2.好處: (1)、維護簡單:模塊化是面向對象編程中的一個...
閱讀 3735·2021-11-24 09:39
閱讀 2616·2019-08-30 15:54
閱讀 1158·2019-08-30 13:01
閱讀 3435·2019-08-28 18:30
閱讀 1630·2019-08-26 17:44
閱讀 3598·2019-08-26 11:31
閱讀 2421·2019-08-26 10:40
閱讀 1251·2019-08-26 10:27