天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript 面向對象,實現namespace,class,繼承,重載

由于組里項目大多的Javascript,css等客戶端工作是另一同事在負責,該同事又特忙無法重構,老大也就只是提建議并未立即實施重構。但是我前些日子也改過些許客戶端的小bug,確實那代碼看得讓人有些云里霧里,不知身在哪山,輕易不敢動代碼,于是就自己動手鼓搗起我曾又愛又恨的Javascript來,自己寫一個簡單的js實現namespace,繼承,重載等面向對象的特性.歡迎拍磚灌水
.定義namespace
Namesapce.js
復制代碼 代碼如下:
Namespace = new Object();
Namespace.register = function(fullname){
try
{
var nsArray = fullname.split(".");
var strNS = "";
var strEval = "";
for(var i=0;i<nsArray.length;i++){
if(strNS.length >0)
strNS += ".";
strNS += nsArray[i];
strEval += " if(typeof("+ strNS +") =='undefined') " + strNS + " = new Object(); ";
}
if(strEval != "") eval(strEval);
}catch(e){alert(e.message);}
}

.Employee.js
Employee.js
復制代碼 代碼如下:
//注冊命名空間
Namespace.register("MyCompany");
//1.類:雇員
MyCompany.Employee = function(empName){
this.Name = empName;
this.Salary = 1000;
this.Position = "cleaner";
}
MyCompany.Employee.prototype.ShowName = function(){
return "I'm "+this.Name+",my salary is $" + this.Salary;
}
MyCompany.Employee.prototype.Work = function(){
return "I'm a "+ this.Position +",I'm cleaning all day!"
}
//2.類:程序員
MyCompany.Developer = function(empName){
//繼承父類屬性
MyCompany.Employee.call(this,empName);
//覆蓋父類屬性
this.Position = "developer";
//擴展屬性
this.Technology = "C#";
}
//繼承父類原型方法
MyCompany.Developer.prototype = new MyCompany.Employee();
//覆蓋父類方法
MyCompany.Developer.prototype.Work = function(){
return "I'm a "+ this.Position +",i'm good at "+ this.Technology +",i'm coding all day!"
}

測試代碼
復制代碼 代碼如下:
<html>
<title>Javascript 面向對象的實現 namespace,class,繼承,重載</title>
<head>
<script language="Javascript" src="namespace.js" type="text/Javascript"></script>
<script language="Javascript" src="employee.js" type="text/Javascript"></script>
<script language="Javascript" type="text/Javascript">
    function showEmployee(){                
        var emp = new MyCompany.Employee("xiaoming");
        showInfo(emp);
    }
    function showDeveloper(){
        var emp = new MyCompany.Developer("Gates");
        showInfo(emp);
    }    
    function showInfo(emp){
        alert(emp.ShowName());
        alert(emp.Work());
    }
</script>
</head>
<body>
<input type="button" value="show employee info" onclick="showEmployee();"/><br/><br/>
<input type="button" value="show developer info" onclick="showDeveloper();"/>
</body>
</html>

源代碼打包下載

JavaScript技術javascript 面向對象,實現namespace,class,繼承,重載,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 成 人 网 站免费观看 | 99热这里只有精品视频2 | 亚洲 欧美 国产 伦 综合 | 丰满人妻熟女色情A片 | 精品亚洲一区二区三区在线播放 | 中文字幕免费在线视频 | 欧美精品高清在线观看 | 久久久伊人影院 | 亚洲AV无码专区国产精品麻豆 | 午夜伦理在线观看 | 亚洲精品嫩草研究院久久 | 国产成人一区免费观看 | 亚洲精品蜜夜内射 | 国内精品久久影视免费 | 高清不卡伦理电影在线观看 | 99精品国产免费久久久久久下载 | 久久中文字幕免费视频 | 亚州视频一区 | 色欲av蜜臀av高清 | 国产又粗又猛又爽黄老大爷 | 国产成人aaa在线视频免费观看 | 国产视频精品在线偷拍 | 精品午夜寂寞影院在线观看 | 久久久国产精品免费A片蜜臀 | 男女性杂交内射妇女BBWXZ | 女人色极品影院 | 在线日本v二区不卡 | 久久视频这里只精品99热在线 | 理论片87福利理论电影 | 中文字幕在线观看 | 99re6久久在热线视频 | 色琪琪无码成人AV视频 | 艳鉧动漫1~6全集观看在线 | 第四色播日韩AV第一页 | 亚婷婷洲AV久久蜜臀无码 | 亚洲免费视频观看 | 日本 一二三 不卡 免费 | 国产精品JK白丝AV网站 | 亚洲国产精品第一影院在线观看 | 小蝌蚪视频在线观看免费观看WWW | 纯肉高H种马艳遇风流多 |