国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript實現多態和繼承的封裝操作示例

2019-11-19 13:12:33
字體:
來源:轉載
供稿:網友

本文實例講述了JavaScript實現多態和繼承的封裝操作。分享給大家供大家參考,具體如下:

封裝Encapsulation

如下代碼,這就算是封裝了

(function (windows, undefined) {  var i = 0;//相對外部環境來說,這里的i就算是封裝了})(window, undefined);

繼承Inheritance

(function (windows, undefined) {  //父類  function Person() { }  Person.prototype.name = "name in Person";  //子類  function Student() { }  Student.prototype = new Person();      //修復原型  Student.prototype.constructor = Student;  //構造函數  Student.prototype.supr = Person.prototype; //父類  //創建子類實例  var stu = new Student();  Student.prototype.age = 28;  Student.prototype.name = "name in Student instance";  //打印子類成員及父類成員  console.log(stu.name); //name in Student instance  console.log(stu.supr.name); //name in Person  console.log(stu.age); //28})(window, undefined);

使用在線HTML/CSS/JavaScript代碼運行工具 http://tools.VeVB.COm/code/HtmlJsRun,運行結果如下:

多態Polymorphism

有了繼承,多態就好辦了

//這就是繼承了(function (windows, undefined) {  //父類  function Person() { }  Person.prototype.name = "name in Person";  Person.prototype.learning = function () {    console.log("learning in Person")  }  //子類  function Student() { }  Student.prototype = new Person();      //修復原型  Student.prototype.constructor = Student;  //構造函數  Student.prototype.supr = Person.prototype; //父類  Student.prototype.learning = function () {    console.log("learning in Student");  }  //工人  function Worker() { }  Worker.prototype = new Person();      //修復原型  Worker.prototype.constructor = Worker;  //構造函數  Worker.prototype.supr = Person.prototype; //父類  Worker.prototype.learning = function () {    console.log("learning in Worker");  }  //工廠  var personFactory = function (type) {    switch (type) {      case "Worker":        return new Worker();        break;      case "Student":        return new Student();        break;    }    return new Person();  }  //客戶端  var person = personFactory("Student");  person.learning(); //learning in Student  person = personFactory("Worker");  person.learning(); //learning in Worker})(window, undefined);

使用在線HTML/CSS/JavaScript代碼運行工具 http://tools.VeVB.COm/code/HtmlJsRun,運行結果如下:

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 凯里市| 梅州市| 临西县| 延长县| 噶尔县| 黄梅县| 房山区| 沁水县| 忻州市| 大城县| 原平市| 渝北区| 江都市| 安化县| 郎溪县| 大新县| 松溪县| 涿鹿县| 迭部县| 张北县| 泸西县| 玉溪市| 贵阳市| 长垣县| 江孜县| 印江| 乌审旗| 北川| 平谷区| 文山县| 平安县| 富裕县| 故城县| 婺源县| 左权县| 峨边| 博兴县| 伊宁县| 邯郸市| 河南省| 喀喇|