javascript prototype原型操作筆記
更新時間:2009年12月07日 19:22:55 作者:
在 JavaScript 中,prototype 不但能讓對象共享自己財富,而且 prototype 還有尋根問祖的天性,從而使得先輩們的遺產(chǎn)可以代代相傳。
復制代碼 代碼如下:
//var People={name:"xiong",age:15};
//var Person=function(user,age){
// this.name=user;
// this.age=age;
// this.say=function(){alert("I am "+this.name+"\n"+this.age);}
//}
//var Chairman=function(name,salary){
// Person.call(this,name);
// }
//var Bill=new Person("Bill",15);
//var Hu=new Chairman("Hu Jintao");
//Person.prototype.eat=function(){
// alert("I'm eating");
// }
//Bill.eat();
function Person(name) //基類構(gòu)造函數(shù)
{
this.name = name;
};
Person.prototype.SayHello = function() //給基類構(gòu)造函數(shù)的 prototype 添加方法
{
alert("Hello, I'm " + this.name);
};
function Employee(name, salary) //子類構(gòu)造函數(shù)
{
Person.call(this, name); //調(diào)用基類構(gòu)造函數(shù)
this.salary = salary;
};
function Xiong(name,age){
Employee.call(this,name);
}
Employee.prototype = new Person(); //建一個基類的對象作為子類原型的原型,這里很有意思
Xiong.prototype=new Employee();
Employee.prototype.ShowMeTheMoney = function() //給子類添構(gòu)造函數(shù)的 prototype 添加方法
{
alert(this.name + " $" + this.salary);
};
var BillGates = new Person("Bill Gates"); //創(chuàng)建基類 Person 的 BillGates 對象
var SteveJobs = new Employee("Steve Jobs", 1234); //創(chuàng)建子類 Employee 的 SteveJobs對象
var hiakuotiankong=new Xiong("海闊天空");
var benbenxiong=new Xiong("笨笨熊");
// BillGates.SayHello(); //通過對象直接調(diào)用到 prototype 的方法
// hiakuotiankong.SayHello(); //通過子類對象直接調(diào)用基類 prototype 的方法,關注!
benbenxiong.SayHello=function(){ //掩蓋了原型的 SayHello 方法
alert("haha,I'm"+this.name);
}
benbenxiong.SayHello();
// SteveJobs.ShowMeTheMoney(); //通過子類對象直接調(diào)用子類 prototype 的方法
// alert(BillGates.SayHello == SteveJobs.SayHello); //顯示:true,表明 prototype 的方法是共享的
Xiong.prototype.Goodbye=function(){
alert(this.name+"Bye-bye");
}
benbenxiong.Goodbye();
在 JavaScript 中,prototype 不但能讓對象共享自己財富,而且 prototype 還有尋根問祖的
天性,從而使得先輩們的遺產(chǎn)可以代代相傳。當從一個對象那里讀取屬性或調(diào)用方法時,如果該對象自
身不存在這樣的屬性或方法,就會去自己關聯(lián)的 prototype 對象那里尋找;如果 prototype 沒有,又會
去 prototype 自己關聯(lián)的前輩 prototype 那里尋找,直到找到或追溯過程結(jié)束為止。
在 JavaScript 內(nèi)部,對象的屬性和方法追溯機制是通過所謂的 prototype 鏈來實現(xiàn)的。當用 new
操作符構(gòu)造對象時,也會同時將構(gòu)造函數(shù)的 prototype 對象指派給新創(chuàng)建的對象,成為該對象內(nèi)置的原
型對象。對象內(nèi)置的原型對象應該是對外不可見的,盡管有些瀏覽器(如 Firefox)可以讓我們訪問這個
內(nèi)置原型對象,但并不建議這樣做。內(nèi)置的原型對象本身也是對象,也有自己關聯(lián)的原型對象,這樣就
形成了所謂的原型鏈。
在原型鏈的最末端,就是 Object 構(gòu)造函數(shù) prototype 屬性指向的那一個原型對象。這個原型對象
是所有對象的最老祖先,這個老祖宗實現(xiàn)了諸如 toString 等所有對象天生就該具有的方法。其他內(nèi)置
構(gòu)造函數(shù),如 Function, Boolean, String, Date 和 RegExp 等的 prototype 都是從這個老祖宗傳承下
來的,但他們各自又定義了自身的屬性和方法,從而他們的子孫就表現(xiàn)出各自宗族的那些特征。
您可能感興趣的文章:
- javascript prototype的深度探索不是原型繼承那么簡單
- JavaScript為對象原型prototype添加屬性的兩種方式
- js中使用使用原型(prototype)定義方法的好處詳解
- javascript prototype原型詳解(比較基礎)
- javascript prototype 原型鏈
- JS構(gòu)造函數(shù)與原型prototype的區(qū)別介紹
- 跟我學習javascript的prototype原型和原型鏈
- js使用原型對象(prototype)需要注意的地方
- 淺談js構(gòu)造函數(shù)的方法與原型prototype
- [js高手之路]圖解javascript的原型(prototype)對象,原型鏈實例
- Javascript 原型和繼承(Prototypes and Inheritance)
- JS原型prototype和__proto__用法實例分析
相關文章
用javascript動態(tài)調(diào)整iframe高度的代碼
用javascript動態(tài)調(diào)整iframe高度的代碼...2007-04-04通過Javascript讀取本地Excel文件內(nèi)容的代碼示例
這篇文章主要介紹了通過Javascript讀取本地Excel文件內(nèi)容的代碼示例,但需要一定的條件才可以使用js操作本地文件,需要的朋友參考下吧2014-04-04toString.call()通用的判斷數(shù)據(jù)類型方法示例
這篇文章主要給大家介紹了關于toString.call()通用的判斷數(shù)據(jù)類型方法的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-08-08JavaScript使用FileReader實現(xiàn)圖片上傳預覽效果
這篇文章主要為大家詳細介紹了JavaScript使用FileReader實現(xiàn)圖片上傳預覽效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-09-09JS實現(xiàn)提交表單前的數(shù)字及郵箱校檢功能
在項目開發(fā)中經(jīng)常會遇到表單提交功能,今天小編抽空給大家分享JS實現(xiàn)提交表單前的數(shù)字及郵箱校檢功能,需要的朋友參考下吧2017-11-11Javascript中判斷一個值是否為undefined的方法詳解
這篇文章給大家詳細介紹了在Javascript中如何判斷一個值是否為undefined,對大家的日常工作和學習很有幫助,下面來一起看看吧。2016-09-09