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

javascript 對象定義方法 簡單易學

工廠模式:
初級開發者可能會這樣定義對象:
var obj = new Object();
obj.name = "hero";
obj.showName=function (){alert(this.name);}
這里存在一個問題就是如果我們要在多個地方用obj對象,可能在程序中類似的代碼要寫好多遍,于是產生了工廠方法
function createObj()
{
var obj = new Object();
obj.name="hero";
obj.showName=function (){alert(this.name);}
return obj;
}
var obj1 = createObj();
var obj2 = createObj();
和另外一種方法 構造函數法
function obj (name)
{
this.name=name;
this.showName= function (){alert(this.name);}
}
把生成對象的代碼封裝起來,避免出現重復new的代碼,當然也可以進一步改進,就是createObj傳遞一些參數,而不是給obj賦默認固定值:
function createObj(name)
{
var obj = new Object();
obj.name=name;
obj.showName=function (){alert(this.name);}
return obj;
}
var obj1 = createObj("hero");
var o'b'j2=createObj("dby");
但是存在一個問題,就是我們每次調用createObj函數都會創建新的函數 showName.意味著每個對象都有自己版本的showName,所以要改進避開這個問題.
function showName()
{
alert(this.name)
}
function createObj(name)
{
var obj = new Object();
obj.name=name;
obj.showName=showName;
return obj;
}
這樣就解決了 重復創建函數的問題, 哈哈哈,大功告成 .
原型方式:
主要是利用對象的prototype屬性.
function obj()
{}
obj.prototype.name="hero";
obj.prototype.showName=function()
{
alert(this.name);
}
看起來似乎比剛才的工廠還完美,但是 有一個問題,該函數沒有構造函數,屬性是通過prototype指定的,這一點在實際應用中很讓人頭疼,所有的實例的屬性都一樣實在是不能讓人接受.尤其還存在一個安全隱患,那就是當對象中有引用時,例如 加上這樣一段
obj.prototype.nameArray = new Array("hero","dby");
然后
obj1 = new obj();
obj2 = new obj();
obj1.nameArray.push("lxw");
在obj2的nameArray中將也會看到這個屬性,因為兩個對象的nameArray指向的是同一個引用.
所以這種方式并不是理想方法.
需要 改進
結合構造函數,在構造函數定義屬性,用原型定義方法
例如
fuction obj(name)
{
this.name = name
this.nameArray = new Array("hero","dby");
}
obj.prototype.showName = function(){alert(this.name)}
所有的非函數屬性都在構造函數里創建,函數屬性用prototype方式創建,obj1 中改變nameArray的值,不會影響到obj2對象的nameArray的值, 而且只有一個showName函數,所以沒有內存浪費.
基本上完美了,剩下的基本都是一下其他的修飾了.有興趣的可以自己改著玩玩.
筆者在這里加上一個單例 玩了一下:
function obj (name)
{
this.name = name;
this.nameArray=new Array("hero","dby");
if(typeof obj._initialized=='undefined')
{
obj.prototype.showName=function(){alert(this.name);}
obj._initialized="true";
}
}
其實不算是單例, 只不過是在構造對象的時候,先判斷一個屬性是否被定義,如果沒有定義,那么用原型方法繼續定義對象,如果已經定義了屬性,那么就不在重復定義函數了. 該prototype方法只被創建一次,病賦值一次.
又差不多完美了,大功告成 .
這是個人的理解,,希望對大家有幫助,不完善的地方請qq聯系,及時改正。
這是一個完整的實例:
function Rectangle(name,color,width,heigth){
this.name=name;
this.color=color;
this.width=width;
this.heigth=heigth;
}
Rectangle.prototype.area=function(){
return this.width*this.heigth
}
Rectangle.prototype.show=function(){
document.write(this.name+" "+this.color+" "+this.width+" "+this.heigth+"<br/>");
document.write(this.area());
}
var obj1= new Rectangle("Rectangle","red",15,20);
obj1.show();

JavaScript技術javascript 對象定義方法 簡單易學,轉載需保留來源!

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

主站蜘蛛池模板: 最近中文字幕2018MV高清在线 | 亚洲AV无码一区二区三区乱子伦 | 伊人久久丁香色婷婷啪啪 | 青娱乐极品视觉盛宴av | freevideoshd| 国产亚洲精品高清视频免费 | 女同给老师下媚药 | 单亲妈妈3韩国电影免费观看 | 草草久久久无码国产专区全集观看 | va亚洲va天堂va视频在线 | 亚洲精品乱码电影在线观看 | wwww69| 国产亚洲精品久久久久久一区二区 | 亚洲三级视频在线观看 | 亚洲色欲色欲综合网站 | 久久国产欧美日韩精品免费 | 亚洲伊人久久一次 | 啊轻点灬大JI巴又大又粗 | 日本乱子人伦在线视频 | 无码日韩人妻精品久久蜜桃入口 | 9久久免费国产精品特黄 | 久久久久久天天夜夜天天 | 99久久精品费精品蜜臀AV | 2017天天拍天天拍香蕉视频 | jizzjizz3d动漫| 国产亚洲精品久久久久苍井松 | 日本无码专区亚洲麻豆 | 中文国产乱码在线人妻一区二区 | 青青久在线 | 欧美日韩另类在线观看视频 | 伊人久久精品AV无码一区 | 国产精品爽爽久久久久久蜜桃网站 | 浪荡受自我调教纯肉BL | 国内精品久久 | 国产成人在线播放 | 久久伊人男人的天堂网站 | 日本 稀土矿 | 久久99精品视频 | 免费果冻传媒在线完整观看 | 婷婷五月久久丁香国产综合 | 亚洲欧美日韩在线观看一区二区三区 |