js活用事件觸發(fā)對(duì)象動(dòng)作
更新時(shí)間:2008年08月10日 20:12:29 作者:
現(xiàn)在基本上我很少在對(duì)象里面寫事情觸發(fā)行為了,因?yàn)楦杏X那樣做相同的對(duì)象代碼利用率太低,容易導(dǎo)致代碼冗余.
從學(xué)習(xí)W3C標(biāo)準(zhǔn)以來,對(duì)于代碼我好像養(yǎng)成了一種怪癖,能統(tǒng)一復(fù)用的,就不會(huì)多寫一點(diǎn)東西,這樣前臺(tái)頁面代碼看起來會(huì)清爽很多,而效率也會(huì)成直線上升.
<script type="text/javascript">
<!--
//定義鼠標(biāo)觸發(fā)事件的范圍
function findOutDiv(thisEvent){
//利用循環(huán)查找符合CSS樣式名字的對(duì)象
while(thisEvent.className != "piccell"){
//如果這個(gè)對(duì)象的標(biāo)簽名字是HTML就停止,然后讓事件對(duì)象不存在,用做后面的判斷
if(thisEvent.tagName == "HTML"){
thisEvent = false;
break;
}else{
//否則繼續(xù)下個(gè)對(duì)象,即他的父對(duì)象
thisEvent = thisEvent.parentNode
}
}
//返回事件對(duì)象,如果事件對(duì)象不存在返回假
return thisEvent;
}
//利用鼠標(biāo)在對(duì)象移動(dòng)屬性作為時(shí)間觸發(fā)行為
document.onmouseover = function(e){
//這個(gè)e是FireFox捕捉事件觸發(fā)對(duì)象的方法
if(!e)e = window.event;
//定義Event給于鼠標(biāo)觸發(fā)對(duì)象的實(shí)體,即符合標(biāo)準(zhǔn)并可以控制的對(duì)象
//target為FF專用,srcElement為IE專用
var Event = e.target?e.target:e.srcElement
//定義可控制的對(duì)象,調(diào)用鼠標(biāo)觸發(fā)事件范圍所返回的對(duì)象
var thisEvent = findOutDiv(Event)
//如果對(duì)象存在就繼續(xù)
if(thisEvent){
//給對(duì)象定義CSS樣式
thisEvent.style.border = "2px solid #7A99D2";
thisEvent.style.background = "#D2E4FC";
}
}
//同上,利用鼠標(biāo)在對(duì)象移出作為時(shí)間觸發(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>
這樣寫的好處顯而易見,可以不用在每個(gè)對(duì)象中寫觸發(fā)動(dòng)作的行為,極大的節(jié)省了代碼,并且JS更有可讀性.
過段時(shí)間等我把個(gè)性化頁面整理完成后發(fā)布出來,讓大家看看利用事件觸發(fā)對(duì)象動(dòng)作的好處.
GOOGLE,和微軟的LIVE他的個(gè)性化頁面寫的很不錯(cuò),所以大家都可以學(xué)習(xí)一下他們的代碼,這樣對(duì)你將來的AJAX應(yīng)用會(huì)有非常大的幫助.
復(fù)制代碼 代碼如下:
<script type="text/javascript">
<!--
//定義鼠標(biāo)觸發(fā)事件的范圍
function findOutDiv(thisEvent){
//利用循環(huán)查找符合CSS樣式名字的對(duì)象
while(thisEvent.className != "piccell"){
//如果這個(gè)對(duì)象的標(biāo)簽名字是HTML就停止,然后讓事件對(duì)象不存在,用做后面的判斷
if(thisEvent.tagName == "HTML"){
thisEvent = false;
break;
}else{
//否則繼續(xù)下個(gè)對(duì)象,即他的父對(duì)象
thisEvent = thisEvent.parentNode
}
}
//返回事件對(duì)象,如果事件對(duì)象不存在返回假
return thisEvent;
}
//利用鼠標(biāo)在對(duì)象移動(dòng)屬性作為時(shí)間觸發(fā)行為
document.onmouseover = function(e){
//這個(gè)e是FireFox捕捉事件觸發(fā)對(duì)象的方法
if(!e)e = window.event;
//定義Event給于鼠標(biāo)觸發(fā)對(duì)象的實(shí)體,即符合標(biāo)準(zhǔn)并可以控制的對(duì)象
//target為FF專用,srcElement為IE專用
var Event = e.target?e.target:e.srcElement
//定義可控制的對(duì)象,調(diào)用鼠標(biāo)觸發(fā)事件范圍所返回的對(duì)象
var thisEvent = findOutDiv(Event)
//如果對(duì)象存在就繼續(xù)
if(thisEvent){
//給對(duì)象定義CSS樣式
thisEvent.style.border = "2px solid #7A99D2";
thisEvent.style.background = "#D2E4FC";
}
}
//同上,利用鼠標(biāo)在對(duì)象移出作為時(shí)間觸發(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>
這樣寫的好處顯而易見,可以不用在每個(gè)對(duì)象中寫觸發(fā)動(dòng)作的行為,極大的節(jié)省了代碼,并且JS更有可讀性.
過段時(shí)間等我把個(gè)性化頁面整理完成后發(fā)布出來,讓大家看看利用事件觸發(fā)對(duì)象動(dòng)作的好處.
GOOGLE,和微軟的LIVE他的個(gè)性化頁面寫的很不錯(cuò),所以大家都可以學(xué)習(xí)一下他們的代碼,這樣對(duì)你將來的AJAX應(yīng)用會(huì)有非常大的幫助.
您可能感興趣的文章:
- javascript 動(dòng)態(tài)改變onclick事件觸發(fā)函數(shù)代碼
- javascript的事件觸發(fā)器介紹的實(shí)現(xiàn)
- javascript下對(duì)于事件、事件流、事件觸發(fā)的順序隨便說說
- javascript 不讓鼠標(biāo)事件觸發(fā)
- js實(shí)現(xiàn)瀏覽器窗口大小被改變時(shí)觸發(fā)事件的方法
- js 觸發(fā)select onchange事件代碼
- js觸發(fā)onchange事件的方法說明
- js獲取事件源及觸發(fā)該事件的對(duì)象
- 代碼觸發(fā)js事件(click、change)示例應(yīng)用
- js事件觸發(fā)操作實(shí)例分析
相關(guān)文章
動(dòng)態(tài)加載圖片路徑 保持JavaScript控件的相對(duì)獨(dú)立性
根據(jù)新界面的要求,需要一部分圖片來增強(qiáng)日期控件的美觀性??紤]到既要實(shí)現(xiàn)加載圖表的目標(biāo),又要保持控件的獨(dú)立性以便將來的移植。2010-09-09使用TextRange獲取輸入框中光標(biāo)的位置的代碼
使用TextRange獲取輸入框中光標(biāo)的位置的代碼...2007-03-03JS中的六種繼承方式以及優(yōu)缺點(diǎn)總結(jié)
JS作為面向?qū)ο蟮娜躅愋驼Z言,繼承也是其非常強(qiáng)大的特性之一,那么如何在JS中實(shí)現(xiàn)繼承呢?下面這篇文章主要給大家介紹了關(guān)于JS中六種繼承方式以及優(yōu)缺點(diǎn)的相關(guān)資料,需要的朋友可以參考下2021-10-10js 數(shù)組倒序排列的具體實(shí)現(xiàn)
有時(shí)候需要將數(shù)組類型變量?jī)?nèi)的元素顛倒一下順序再輸出,本文就詳細(xì)的介紹一下,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08el-input 標(biāo)簽中密碼的顯示和隱藏功能的實(shí)例代碼
本文通過實(shí)例代碼給大家介紹了el-input 標(biāo)簽中密碼的顯示和隱藏 ,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07JS和css實(shí)現(xiàn)檢測(cè)移動(dòng)設(shè)備方向的變化并判斷橫豎屏幕
這篇文章主要介紹了JS和css實(shí)現(xiàn)檢測(cè)移動(dòng)設(shè)備方向的變化并判斷橫豎屏幕,本文分別給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-05-05javascript 拖動(dòng)表格行實(shí)現(xiàn)代碼
用js實(shí)現(xiàn)的拖動(dòng)表格的tr行的實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-05-05使用requirejs模塊化開發(fā)多頁面一個(gè)入口js的使用方式
這篇文章主要介紹了使用requirejs模塊化開發(fā)多頁面一個(gè)入口js的使用方式,需要的朋友可以參考下2017-06-06