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

javascript 命名空間以提高代碼重用性

當(dāng)在同一個網(wǎng)頁里引入10多個js文件之后,
各js中的同名函數(shù)就很容易沖突了。
比如xxx庫里寫了個addCssStyle方法,
yyy類庫里也寫了個addCssStyle方法,
而這兩個方法的具體實(shí)現(xiàn)又有一定差別。
那么同時引用這兩個組件的時候,函數(shù)沖突之后導(dǎo)致頁面效果發(fā)生變化,
調(diào)試和修改都是非常痛苦的,如果為了避免沖突,
而放棄引用一些優(yōu)秀的組件,那更是讓人郁悶的事情。

為此,在封裝Javascript組件庫的時候,請使用命名空間來避免沖突。
將所有的方法和變量都要按包名類名的方式來寫。
(這個時候?qū)懘a的感覺和封裝Java的util方法一樣方便,呵呵)
由此,我的js庫按如下方式封裝。
google了半天,都沒現(xiàn)成的,于是自己摸索出來,示例代碼如下:
(lizongbo原創(chuàng)!!!)

<script language="JavaScript" type="text/Javascript" >
<!-- //初始化命名空間
var jscom = jscom ? jscom : {};
jscom.lizongbo = jscom.lizongbo ? jscom.lizongbo : {};
//第一種封裝方法
jscom.lizongbo.util = jscom.lizongbo.util ? jscom.lizongbo.util : {
crtVersion : 'jscom.lizongbo.util version 0.0.1', //注意用逗號隔開
sayHello: function (str){
window.alert('hello : '+str +' by ' + this.getVersion()); //變量引用要加上this
},//注意用逗號隔開
getVersion :function (){
//alert(' jscom.lizongbo.util version ' + this.crtVersion);//變量引用要加上this
return this.crtVersion+' lizongbo';
}//注意不能夠有逗號
}
//第二種封裝方法
jscom.lizongbo.util2 =function (){};//重點(diǎn)是這行,它保證了下面的with調(diào)用
jscom.lizongbo.util2.crtVersion=' jscom.lizongbo.util2 version 0.0.2';
jscom.lizongbo.util2.sayHello = function(str){
with (jscom.lizongbo.util2) {//這里也是重點(diǎn),不然會找不到getVersion方法。
window.alert('你好 : '+str +' by ' + getVersion());//這種方法不用加this
}
};
jscom.lizongbo.util2.getVersion = function(){
with (jscom.lizongbo.util2) {//這里也是重點(diǎn),不然會找不到crtVersion變量。
return crtVersion+' lizongbo2';
}
};
var vutil1= jscom.lizongbo.util; //和Java的import差不多好用
vutil1.sayHello('lizongbo'); //第一種調(diào)用
var vutil2= jscom.lizongbo.util2;
vutil2.sayHello('lizongbo');//第二種調(diào)用
//-->
</script>

把上面的代碼復(fù)制網(wǎng)頁里看看效果吧。
對比兩種實(shí)現(xiàn)方式,現(xiàn)有代碼按第二種方式改造最為方便。
再把js文件按命名空間命名,那樣操作就更加方便了。
例如
<script type="text/Javascript" src="/commons/scripts/jscom.lizongbo.util1.js"></script>
<script type="text/Javascript" src="/commons/scripts/jscom.lizongbo.util2.js"></script>
只要都按此方式編寫的庫,再也不用擔(dān)心引入多個js文件之后的函數(shù)沖突問題了。

JavaScript技術(shù)javascript 命名空間以提高代碼重用性,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 蜜臀久久99精品久久久久久做爰 | 精品国产自在天天线2019 | 成人免费视频在线观看 | 91亚洲精品福利在线播放 | 9420高清免费观看在线大全 | 久久精品一区二区影院 | 日日噜噜噜噜夜夜爽亚洲精品 | 99国产热视频在线观看 | 男女后进式猛烈xx00动态图片 | 日韩特黄特色大片免费视频 | 用震蛋调教女性下面视频 | 国内精品久久久久影院男同志 | 欧洲老妇人bb | 好爽胸大好深好多水 | 国产精品JIZZ在线观看A片 | 文中字幕一区二区三区视频播放 | 国产小视频免费在线观看 | 亚洲国产货青视觉盛宴 | 国产成人精品免费视频软件 | 无码欧美喷潮福利XXXX | 九九久久国产精品大片 | 女bbbbxxx孕妇 | 香蕉久久一区二区三区啪啪 | 亚洲视频精选 | 青青草AV国产精品 | 久久伊人中文字幕有码 | AV无码国产精品午夜A片麻豆 | 四房播播开心色播 | 久久亚洲AV无码精品午色夜麻豆 | 亚洲AV无码一区二区三区乱子伦 | 日本zljzljzlj精品 | 亚洲无吗精品AV九九久久 | 第一会所欧美无码原创 | 高清国语自产拍在线 | 不分昼夜H1V3 | 极品少妇高潮啪啪无码吴梦 | 亚洲一区二区三不卡高清 | 欧美.亚洲.日韩.天堂 | 漂亮的保姆6在线观看中文 漂亮的保姆5电影免费观看完整版中文 | 国产精品一区二区AV交换 | 成人 迅雷下载 |