用Mootools獲得操作索引的兩種方法分享
更新時(shí)間:2011年12月12日 20:15:56 作者:
用Mootools獲得操作索引的兩種方法分享,需要的朋友可以參考下。
我們先說一下第一種方法,(此方法為一位QQ好友提供,感謝此人,此人昵稱是:exf)
<body>
<ul>Title1
<li>11111</li>
</ul>
<ul>Title2
<li>22222</li>
</ul>
<ul>Title3
<li>33333</li>
</ul>
<ul>Title4
<li>44444</li>
</ul>
<script type='text/javascript'>
ul=$$('ul');
ul.addEvent('click',function(){
alert(ul.indexOf(this));
});
</script>
其實(shí)除了上邊的方法外還有一種方法也能得到索引值,看下邊的例子:
<body>
<ul>Title1
<li>11111</li>
</ul>
<ul>Title2
<li>22222</li>
</ul>
<ul>Title3
<li>33333</li>
</ul>
<ul>Title4
<li>44444</li>
</ul>
<script type='text/javascript'>
ul=$$('ul');
ul.each(function($I,i){
$I.onclick=function(){
alert(i);
};
})
</script>
兩種方法孰優(yōu)孰劣一看便知,第一種方法需要再次使用indexOf函數(shù)判斷,而第二種方式直接是作為參數(shù)把索引值傳遞進(jìn)去了,就不需要額外的計(jì)算了.因此如果您需要獲取索引值得時(shí)候推薦使用第二種方法.
下邊我寫了一個(gè)手風(fēng)琴插件用來演示兩種方法在實(shí)際應(yīng)用過程中的表現(xiàn).
<style type="text/css">
ul,li{font-size:12px;font-family:arial;padding:0;margin:0;}
ul{width:300px;line-height:24px;font-weight:bold;background-color:#C1C2C1;border-bottom:1px solid #fff;text-indent:10px;}
li{list-style:none;font-weight:normal;background-color:#e1e1e1;}
</style>
</head>
<body>
<ul>Title1
<li>11111</li>
</ul>
<ul>Title2
<li>22222</li>
</ul>
<ul>Title3
<li>33333</li>
</ul>
<ul>Title4
<li>44444</li>
</ul>
<script type='text/javascript'>
var Acc=new Class({
Implements:[Options,Events],
options:{
$Boxtit:false
},
initialize:function(options){//初始化構(gòu)造函數(shù)
this.setOptions(options);//設(shè)置options
if(!this.options.$Boxtit){return false;}
this.Core();
},
Core:function(){
$Boxtit=this.options.$Boxtit;
$Boxmsg=$Boxtit.getElement('li');
$Boxmsg.setStyle("display","none");
$Boxtit.each(function($I,i1){
$I.onclick=function(){
//i2=$Boxtit.indexOf(this);console.log(i1+'|'+i2);//這裡的i1和i2實(shí)際上都是索引值
$Boxmsg.setStyle("display","none");
this.getElement('li').setStyle("display","");
};
})
}
});
new Acc({$Boxtit:$$('ul')});
</script>
只不過在上邊的插件中為了提高效率,因此我使用了this,這樣比用索引找尋DOM效率更高一些.
復(fù)制代碼 代碼如下:
<body>
<ul>Title1
<li>11111</li>
</ul>
<ul>Title2
<li>22222</li>
</ul>
<ul>Title3
<li>33333</li>
</ul>
<ul>Title4
<li>44444</li>
</ul>
<script type='text/javascript'>
ul=$$('ul');
ul.addEvent('click',function(){
alert(ul.indexOf(this));
});
</script>
其實(shí)除了上邊的方法外還有一種方法也能得到索引值,看下邊的例子:
復(fù)制代碼 代碼如下:
<body>
<ul>Title1
<li>11111</li>
</ul>
<ul>Title2
<li>22222</li>
</ul>
<ul>Title3
<li>33333</li>
</ul>
<ul>Title4
<li>44444</li>
</ul>
<script type='text/javascript'>
ul=$$('ul');
ul.each(function($I,i){
$I.onclick=function(){
alert(i);
};
})
</script>
兩種方法孰優(yōu)孰劣一看便知,第一種方法需要再次使用indexOf函數(shù)判斷,而第二種方式直接是作為參數(shù)把索引值傳遞進(jìn)去了,就不需要額外的計(jì)算了.因此如果您需要獲取索引值得時(shí)候推薦使用第二種方法.
下邊我寫了一個(gè)手風(fēng)琴插件用來演示兩種方法在實(shí)際應(yīng)用過程中的表現(xiàn).
復(fù)制代碼 代碼如下:
<style type="text/css">
ul,li{font-size:12px;font-family:arial;padding:0;margin:0;}
ul{width:300px;line-height:24px;font-weight:bold;background-color:#C1C2C1;border-bottom:1px solid #fff;text-indent:10px;}
li{list-style:none;font-weight:normal;background-color:#e1e1e1;}
</style>
</head>
<body>
<ul>Title1
<li>11111</li>
</ul>
<ul>Title2
<li>22222</li>
</ul>
<ul>Title3
<li>33333</li>
</ul>
<ul>Title4
<li>44444</li>
</ul>
<script type='text/javascript'>
var Acc=new Class({
Implements:[Options,Events],
options:{
$Boxtit:false
},
initialize:function(options){//初始化構(gòu)造函數(shù)
this.setOptions(options);//設(shè)置options
if(!this.options.$Boxtit){return false;}
this.Core();
},
Core:function(){
$Boxtit=this.options.$Boxtit;
$Boxmsg=$Boxtit.getElement('li');
$Boxmsg.setStyle("display","none");
$Boxtit.each(function($I,i1){
$I.onclick=function(){
//i2=$Boxtit.indexOf(this);console.log(i1+'|'+i2);//這裡的i1和i2實(shí)際上都是索引值
$Boxmsg.setStyle("display","none");
this.getElement('li').setStyle("display","");
};
})
}
});
new Acc({$Boxtit:$$('ul')});
</script>
只不過在上邊的插件中為了提高效率,因此我使用了this,這樣比用索引找尋DOM效率更高一些.
相關(guān)文章
Mootools 1.2 手風(fēng)琴(Accordion)教程
繼續(xù)我們的“更多”(More)庫里面的插件教程,今天我們來學(xué)習(xí)一下可能是最流行最受歡迎的插件——手風(fēng)琴。2009-09-09基于mootools 1.3框架下的圖片滑動(dòng)效果代碼
容器采用相對(duì)定位,圖片采用絕對(duì)定位,當(dāng)鼠標(biāo)移動(dòng)到相應(yīng)的圖片上,改變?nèi)eft屬性,用tween實(shí)現(xiàn)動(dòng)畫效果.2011-04-04Mootools 1.2教程 Fx.Morph、Fx選項(xiàng)和Fx事件
今天,我們繼續(xù)探索一下這個(gè)庫的Fx部分2009-09-09分享一個(gè)用Mootools寫的鼠標(biāo)滑過進(jìn)度條改變進(jìn)度值的實(shí)現(xiàn)代碼
分享一個(gè)用Mootools寫的鼠標(biāo)滑過進(jìn)度條改變進(jìn)度值的實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-12-12MooTools 頁面滾動(dòng)浮動(dòng)層智能定位實(shí)現(xiàn)代碼
MooTools 頁面滾動(dòng)浮動(dòng)層智能定位實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-08-08Mootools 1.2教程 選項(xiàng)卡效果(Tabs)
今天將不只是受限于這個(gè)庫和一些基本的編程知識(shí),我們來做一個(gè)簡單的小項(xiàng)目。通過使用我們目前為止已經(jīng)學(xué)過的一些知識(shí),有幾種方式來創(chuàng)建當(dāng)鼠標(biāo)移上去或者點(diǎn)擊時(shí)顯示相應(yīng)內(nèi)容的tab。2009-09-09