成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

javascript必知必會(huì):面象對(duì)象編程

開(kāi)發(fā) 前端
面象對(duì)象編程技術(shù)的核心理念:封裝、繼承、多態(tài);在一些主流的高級(jí)編程語(yǔ)言中,比 如:C#,VB.NET,JAVA,PHP等都是很容易實(shí)現(xiàn)的,而如果要在javascript中實(shí)現(xiàn)面象對(duì)象編程,可就不那么直接和容易了,因?yàn)?javascript并不是面向?qū)ο蟮恼Z(yǔ)言,所以我們只能通過(guò)javascript的一些特性,比如:閉包、原型鏈等來(lái)模擬出面向?qū)ο缶幊蹋艺J(rèn)為這些是 作為熟練掌握與靈活運(yùn)用javascript的基礎(chǔ),園子里已有很多的javascript高手對(duì)于這方面都有介紹與分析,而我僅以作為一個(gè)項(xiàng)目負(fù)責(zé)人 (獨(dú)立設(shè)計(jì)與開(kāi)發(fā)WEB前端與后端)的視角來(lái)重新理解javascript面向?qū)?/div>

面象對(duì)象編程技術(shù)的核心理念:封裝、繼承、多態(tài);在一些主流的高級(jí)編程語(yǔ)言中,比 如:C#,VB.NET,JAVA,PHP等都是很容易實(shí)現(xiàn)的,而如果要在javascript中實(shí)現(xiàn)面象對(duì)象編程,可就不那么直接和容易了,因?yàn)?javascript并不是面向?qū)ο蟮恼Z(yǔ)言,所以我們只能通過(guò)javascript的一些特性,比如:閉包、原型鏈等來(lái)模擬出面向?qū)ο缶幊蹋艺J(rèn)為這些是 作為熟練掌握與靈活運(yùn)用javascript的基礎(chǔ),園子里已有很多的javascript高手對(duì)于這方面都有介紹與分析,而我僅以作為一個(gè)項(xiàng)目負(fù)責(zé)人 (獨(dú)立設(shè)計(jì)與開(kāi)發(fā)WEB前端與后端)的視角來(lái)重新理解javascript面向?qū)ο笠c(diǎn)。

既然是面向?qū)ο螅紫任覀円廊绾蝿?chuàng)建一個(gè)對(duì)象,以下列出了創(chuàng)建對(duì)象的幾種常見(jiàn)方法:

A.直接創(chuàng)建一個(gè)對(duì)象實(shí)例:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

//直接實(shí)例化一個(gè)對(duì)象

var Person1 = { Name: "夢(mèng)在旅途", Age: 29, Sex: "男", Height: 178 };

 

alert(Person1.Name);

 

var Person2 = new Object();

Person2.Name = "夢(mèng)在旅途";

Person2.Age = 29;

Person2.Sex = "男";

Person2.Height = 178;

 

alert(Person2.Name);

 

//這個(gè)是上面的簡(jiǎn)寫

var Person3 = new Object({ Name: "夢(mèng)在旅途", Age: 29, Sex: "男", Height: 178 });

alert(Person3.Name);

優(yōu)點(diǎn):直接創(chuàng)建一個(gè)對(duì)象,無(wú)需提前定義類型;

缺點(diǎn):無(wú)法實(shí)現(xiàn)復(fù)用;

B.先定義后實(shí)例化對(duì)象:

1

2

3

4

5

6

7

8

9

10

//先定義類,再實(shí)例化成對(duì)象

function Person4(n,a,s,h) {

    this.Name = n;

    this.Age = a;

    this.Sex = s;

    this.Height = h;

}

 

var p4 = new Person4("夢(mèng)在旅途", 29, "男", 178);

alert(p4.Age);

優(yōu)點(diǎn):類似面向?qū)ο缶幊陶Z(yǔ)言的構(gòu)造函數(shù),容易理解,且定義后可通過(guò)new關(guān)鍵字實(shí)例化多個(gè)對(duì)象,實(shí)現(xiàn)復(fù)用。

缺點(diǎn):需先定義后才能實(shí)例化;

綜上所述,建議采用B方法來(lái)創(chuàng)建對(duì)象。

實(shí)現(xiàn)封裝,即只暴露公共方法與公共屬性,隱藏實(shí)現(xiàn)細(xì)節(jié)(私有方法、屬性)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

function Person5(n, a, s, h) {

 

    //公共屬性

    this.Name = n;

    this.Age = a;

    this.Sex = s;

    this.Height = h;

     

    //公共方法

    this.AfterYear = function (count) {

        updateAge(count);

        alert(_currentYear +"后,我已經(jīng):" + this.Age +"歲了!");

    };

 

    this.Say = function () {

        alert("我的個(gè)人信息--> Name: "+ this.Name+", Age: "+ this.Age +", Sex: "+ this.Sex +", Height:" + this.Height);

    }

 

    //私有屬性與方法

    var _self = this;

    var _currentYear = 2015;

    function updateAge(count) {

        _currentYear += count;

        _self.Age += count;

    };

}

 

var p5 = new Person5("夢(mèng)在旅途", 29, "男", 178);

p5.AfterYear(10);

p5.AfterYear(25);

利用原型鏈實(shí)現(xiàn)繼承,即一個(gè)對(duì)象包含另一個(gè)對(duì)象的所有公共屬性與方法,實(shí)現(xiàn)繼承的方法有很多,我覺(jué)得采用如下形式來(lái)模擬繼承更符合面向?qū)ο蟮乃季S:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

function SoftEngineer(n, a, s, h, lang) {

    Person5.call(this, n, a, s, h);//將Person5的所有屬性與方法包含到SoftEngineer中,從而實(shí)現(xiàn)繼承

    this.Lang = lang;

    this.SayCode = function () {

        alert("我是一名軟件工程師,我會(huì)" + this.Lang + "編程語(yǔ)言!");

    }

 

    this.Working = function () { };//空方法,類似面向?qū)ο笾械奶摲椒?/code>

}

 

SoftEngineer.prototype = new Person5(); //將SoftEngineer的原型指定Person5的實(shí)例

 

var softengr = new SoftEngineer("夢(mèng)在旅途", 29, "男", 178, "javascript");

softengr.Say();

softengr.SayCode();

利用原型鏈實(shí)現(xiàn)多態(tài),即基于同一個(gè)方法簽名在不同的子類中表現(xiàn)的形式不同:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

function WebSoftEngineer(n, a, s, h, lang) {

    SoftEngineer.apply(this, [n, a, s, h, lang]);

    this.Working = function () {

        alert("我是網(wǎng)頁(yè)工程師,從事網(wǎng)頁(yè)開(kāi)發(fā)設(shè)計(jì)工作!");

    };

};

 

WebSoftEngineer.prototype = new SoftEngineer();

 

function AppSoftEngineer(n, a, s, h, lang) {

    SoftEngineer.apply(this, [n, a, s, h, lang]);

    this.Working = function () {

        alert("我是應(yīng)用工程師,從事客戶端應(yīng)用程序開(kāi)發(fā)設(shè)計(jì)工作!");

    };

};

AppSoftEngineer.prototype = new SoftEngineer();

 

var webengr = new WebSoftEngineer("夢(mèng)在旅途", 29, "男", 178, "javascript");

webengr.Say();

webengr.Working();

 

var appengr = new AppSoftEngineer("夢(mèng)在旅途", 29, "男", 178, "c#");

appengr.Say();

appengr.Working();

 

責(zé)任編輯:王雪燕 來(lái)源: 博客園
相關(guān)推薦

2022-05-18 09:01:19

JSONJavaScript

2020-07-10 07:58:14

Linux

2024-11-15 11:11:48

2024-06-19 10:08:34

GoChannel工具

2024-01-03 07:56:50

2023-10-09 18:52:14

SOLIDJava

2022-08-19 10:31:32

Kafka大數(shù)據(jù)

2024-01-10 18:01:22

編程技巧Java 12

2015-10-20 09:46:33

HTTP網(wǎng)絡(luò)協(xié)議

2019-01-30 14:14:16

LinuxUNIX操作系統(tǒng)

2018-10-26 14:10:21

2023-04-20 14:31:20

Python開(kāi)發(fā)教程

2024-06-13 09:10:22

2024-01-09 13:58:22

PandasPython數(shù)據(jù)分析

2023-05-08 15:25:19

Python編程語(yǔ)言編碼技巧

2023-12-26 12:10:13

2023-09-12 11:25:15

2019-11-06 10:56:59

Python數(shù)據(jù)分析TGI

2024-07-26 08:32:44

panic?Go語(yǔ)言

2022-08-26 14:46:31

機(jī)器學(xué)習(xí)算法線性回歸
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产精品久久久久久久久久久久久久 | 国产精品欧美一区二区三区 | 欧美网址在线观看 | 日本黄视频在线观看 | 97色在线视频 | 久久国产精品免费视频 | 日韩欧美高清dvd碟片 | 亚洲成人免费视频 | 亚洲国产成人精品久久久国产成人一区 | 在线91 | 欧美性影院 | 久久亚洲综合 | 成人福利网站 | 黄色一级网 | 日韩中文一区二区三区 | 日韩av电影院 | 国产精品福利网站 | 国产精品久久久久久久久免费樱桃 | 免费看爱爱视频 | 国产女人与拘做受免费视频 | av高清| 中文字幕国产精品 | 91精品国产自产精品男人的天堂 | 色综合一区二区 | 国产乱xxav| 古装三级在线播放 | 91av视频在线播放 | 一区二区免费 | 日本一区二区三区四区 | 午夜小电影 | 亚洲 欧美 日韩 在线 | 久久久久国产 | 免费高清成人 | 久久久久久国产精品 | 久久婷婷香蕉热狠狠综合 | 欧美国产日韩在线 | 黄色一级电影免费观看 | 福利视频三区 | 欧美一区二区三区在线视频 | 久草网站| 色婷婷综合久久久久中文一区二区 |