js活用事件觸發(fā)對象動作
更新時間:2008年08月10日 20:12:29 作者:
現(xiàn)在基本上我很少在對象里面寫事情觸發(fā)行為了,因為感覺那樣做相同的對象代碼利用率太低,容易導致代碼冗余.
從學習W3C標準以來,對于代碼我好像養(yǎng)成了一種怪癖,能統(tǒng)一復用的,就不會多寫一點東西,這樣前臺頁面代碼看起來會清爽很多,而效率也會成直線上升.
<script type="text/javascript">
<!--
//定義鼠標觸發(fā)事件的范圍
function findOutDiv(thisEvent){
//利用循環(huán)查找符合CSS樣式名字的對象
while(thisEvent.className != "piccell"){
//如果這個對象的標簽名字是HTML就停止,然后讓事件對象不存在,用做后面的判斷
if(thisEvent.tagName == "HTML"){
thisEvent = false;
break;
}else{
//否則繼續(xù)下個對象,即他的父對象
thisEvent = thisEvent.parentNode
}
}
//返回事件對象,如果事件對象不存在返回假
return thisEvent;
}
//利用鼠標在對象移動屬性作為時間觸發(fā)行為
document.onmouseover = function(e){
//這個e是FireFox捕捉事件觸發(fā)對象的方法
if(!e)e = window.event;
//定義Event給于鼠標觸發(fā)對象的實體,即符合標準并可以控制的對象
//target為FF專用,srcElement為IE專用
var Event = e.target?e.target:e.srcElement
//定義可控制的對象,調用鼠標觸發(fā)事件范圍所返回的對象
var thisEvent = findOutDiv(Event)
//如果對象存在就繼續(xù)
if(thisEvent){
//給對象定義CSS樣式
thisEvent.style.border = "2px solid #7A99D2";
thisEvent.style.background = "#D2E4FC";
}
}
//同上,利用鼠標在對象移出作為時間觸發(fā)行為
document.onmouseout = function(e){
if(!e)e = window.event;
var Event = e.target?e.target:e.srcElement
var thisEvent = findOutDiv(Event)
if(thisEvent){
thisEvent.style.border = "2px solid #CCC";
thisEvent.style.background = "#FFF";
}
}
// -->
</script>
這樣寫的好處顯而易見,可以不用在每個對象中寫觸發(fā)動作的行為,極大的節(jié)省了代碼,并且JS更有可讀性.
過段時間等我把個性化頁面整理完成后發(fā)布出來,讓大家看看利用事件觸發(fā)對象動作的好處.
GOOGLE,和微軟的LIVE他的個性化頁面寫的很不錯,所以大家都可以學習一下他們的代碼,這樣對你將來的AJAX應用會有非常大的幫助.
復制代碼 代碼如下:
<script type="text/javascript">
<!--
//定義鼠標觸發(fā)事件的范圍
function findOutDiv(thisEvent){
//利用循環(huán)查找符合CSS樣式名字的對象
while(thisEvent.className != "piccell"){
//如果這個對象的標簽名字是HTML就停止,然后讓事件對象不存在,用做后面的判斷
if(thisEvent.tagName == "HTML"){
thisEvent = false;
break;
}else{
//否則繼續(xù)下個對象,即他的父對象
thisEvent = thisEvent.parentNode
}
}
//返回事件對象,如果事件對象不存在返回假
return thisEvent;
}
//利用鼠標在對象移動屬性作為時間觸發(fā)行為
document.onmouseover = function(e){
//這個e是FireFox捕捉事件觸發(fā)對象的方法
if(!e)e = window.event;
//定義Event給于鼠標觸發(fā)對象的實體,即符合標準并可以控制的對象
//target為FF專用,srcElement為IE專用
var Event = e.target?e.target:e.srcElement
//定義可控制的對象,調用鼠標觸發(fā)事件范圍所返回的對象
var thisEvent = findOutDiv(Event)
//如果對象存在就繼續(xù)
if(thisEvent){
//給對象定義CSS樣式
thisEvent.style.border = "2px solid #7A99D2";
thisEvent.style.background = "#D2E4FC";
}
}
//同上,利用鼠標在對象移出作為時間觸發(fā)行為
document.onmouseout = function(e){
if(!e)e = window.event;
var Event = e.target?e.target:e.srcElement
var thisEvent = findOutDiv(Event)
if(thisEvent){
thisEvent.style.border = "2px solid #CCC";
thisEvent.style.background = "#FFF";
}
}
// -->
</script>
這樣寫的好處顯而易見,可以不用在每個對象中寫觸發(fā)動作的行為,極大的節(jié)省了代碼,并且JS更有可讀性.
過段時間等我把個性化頁面整理完成后發(fā)布出來,讓大家看看利用事件觸發(fā)對象動作的好處.
GOOGLE,和微軟的LIVE他的個性化頁面寫的很不錯,所以大家都可以學習一下他們的代碼,這樣對你將來的AJAX應用會有非常大的幫助.
相關文章
layer.open提交子頁面的form和layedit文本編輯內容的方法
今天小編就為大家分享一篇layer.open提交子頁面的form和layedit文本編輯內容的方法,具有好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
使用iframe window的scroll方法控制iframe頁面滾動
在頁面中如何控制內嵌的iframe滾動呢?方法是使用iframe window的scroll方法,大家可以參考下面的示例2014-03-03

