用Mootools獲得操作索引的兩種方法分享
更新時(shí)間:2011年12月12日 20:15:56 作者:
用Mootools獲得操作索引的兩種方法分享,需要的朋友可以參考下。
我們先說(shuō)一下第一種方法,(此方法為一位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)琴插件用來(lái)演示兩種方法在實(shí)際應(yīng)用過(guò)程中的表現(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>
只不過(guò)在上邊的插件中為了提高效率,因此我使用了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)琴插件用來(lái)演示兩種方法在實(shí)際應(yīng)用過(guò)程中的表現(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>
只不過(guò)在上邊的插件中為了提高效率,因此我使用了this,這樣比用索引找尋DOM效率更高一些.
相關(guān)文章
Mootools 1.2教程 滾動(dòng)條(Slider)
到現(xiàn)在為止,初始化這些MooTools插件對(duì)象就會(huì)開(kāi)始變得越來(lái)越熟悉。滾動(dòng)條(Slider)沒(méi)有任何不同,你要?jiǎng)?chuàng)建一個(gè)新的滾動(dòng)條,定義滾動(dòng)條和滑塊相關(guān)的元素,然后設(shè)置你的選項(xiàng),再創(chuàng)建一些回調(diào)事件的控制函數(shù)。2009-09-09
Mootools 1.2 手風(fēng)琴(Accordion)教程
繼續(xù)我們的“更多”(More)庫(kù)里面的插件教程,今天我們來(lái)學(xué)習(xí)一下可能是最流行最受歡迎的插件——手風(fēng)琴。2009-09-09
分享一個(gè)用Mootools寫的鼠標(biāo)滑過(guò)進(jìn)度條改變進(jìn)度值的實(shí)現(xiàn)代碼
分享一個(gè)用Mootools寫的鼠標(biāo)滑過(guò)進(jìn)度條改變進(jìn)度值的實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-12-12
基于mootools插件實(shí)現(xiàn)遮罩層新手引導(dǎo)
公司項(xiàng)目有這個(gè)需求,剛好這段時(shí)間在學(xué)習(xí)了mootools,于是把功能寫成了mootools插件,個(gè)人感覺(jué)mootools在這方面比jquery強(qiáng)多了2012-05-05
Mootools 1.2教程 定時(shí)器和哈希簡(jiǎn)介
在今天的教程中,我們將關(guān)注兩塊內(nèi)容:第一個(gè)就是.periodical();方法,然后我們?cè)賹?duì)hash做一個(gè)簡(jiǎn)介。2009-09-09
MooTools 1.2中的Drag.Move來(lái)實(shí)現(xiàn)拖放
今天我們開(kāi)始第十二講,今天我們將仔細(xì)看一下Drag.Move——一個(gè)很強(qiáng)大的MooTools類,它可以讓你給你的web應(yīng)用添加拖放功能。2009-09-09
Mootools 1.2教程 輸入過(guò)濾第二部分(字符串)
今天我們來(lái)看一看MooTools給我們提供的額外的一些處理字符函數(shù)。這只是MooTools字符串處理中的一部分,并不包含一些神秘的函數(shù)(比如toCamelCase())和使用正則表達(dá)式處理字符串的函數(shù)。2009-09-09

