事件處理

事件處理是讓頁面實現(xiàn)交互的關(guān)鍵楔绞,沒有事件用戶就只能瞪眼看啦~
js的事件真的好多能扒,涵蓋了你能想到的任何操作(當(dāng)然如眼球追蹤等還沒有實現(xiàn)哈)迟郎,這里我們講解寫我們經(jīng)常會用到的。

在搞事件的時候必要的是先搞一個頁面透硝,不然去操作誰呢 .0.0.

//我們在搞js狰闪,誰會去理會html,能用js的絕對不假手其他語言濒生,就是這么任性
//其實是復(fù)習(xí)一下前面的DOM(不小心說了實話埋泵,裝逼被揭穿 ..0.0..)
//首先我們創(chuàng)建一個div標(biāo)簽(其實這一個標(biāo)簽就夠我們折騰了~)
document.body.innerHTML = '<div></div>';
var _divBox = document.getElementsByTagName('div')[0];
_divBox.style.width = '100px';
_divBox.style.height = '100px';
_divBox.style.background = '#FF0000';
//這時候我們運行頁面就會看到左上角有一個寬100 高100的紅色正方形,如果你的函數(shù)章節(jié)已經(jīng)看過了甜攀,最好把它封裝成一個函數(shù)秋泄,下面會有類似的例子。
  • onload頁面加載時觸發(fā)
window.onload=function(){
   //TODO something
}
//當(dāng)頁面加載的時候觸發(fā)规阀。比如ajax數(shù)據(jù)的加載恒序,樣式定義(有些像素運算問題),都需要在加載時搞定

  • onclick 點擊事件(這個是最多的)
    • 第一種是對象屬性直接定義
//如果你上面的代碼也是寫的這么裸谁撼,你可以接著寫了
_divBox.onclick=function(){
    _divBox.style.background = '#00FF00';
    //this.style.background = '#00FF00';
}
//上面的倆行代碼是一個意思歧胁,其中注釋中的this是指針,指向當(dāng)前對象厉碟,這個在進階篇的面向?qū)ο笾袝v到喊巍。
//回到瀏覽器,打開頁面箍鼓,點擊這個紅色div會發(fā)現(xiàn)它變成了綠色崭参。
  • 第二種是監(jiān)聽addEventListener (attachEvent是IE搞的,感覺IE開發(fā)太另類款咖,喜歡的自己去查查何暮,很簡單)
_divBox.addEventListener('click',function(){
    this.style.background = '#00FF00';
});
//這里我們會看到相同的效果
  * 這兩個函數(shù)雖然有著相同的效果,但是不同的铐殃,當(dāng)我們使用第一種方法為_divBox的onclick屬性設(shè)定幾個不同的函數(shù)時海洼,只會執(zhí)行最后一個。而addEventListener則會將幾個函數(shù)都執(zhí)行一遍富腊。
  * 另外坏逢,addEventListener有3個參數(shù)(有一個默認(rèn)的useCapture為false,我們就省略了);當(dāng)為false時采用冒泡模式監(jiān)聽赘被,為true則是capture/捕獲模式監(jiān)聽是整,我們用下面的代碼來看看區(qū)別:
//我們需要先在_divBox里面繼續(xù)插入一個p標(biāo)簽
_divBox.innderHTML='<p>this is para</p>';
//然后定義兩個監(jiān)聽事件
_divBox.addEventListener('click',function(){
    console.log('div');
},true);
document.getElementsByTagName('p')[0].addEventListener('click',function(){
   console.log('p');
},true);
//在瀏覽器中運行,點擊div會看到輸出div民假,點擊p會看到先輸出div然后輸出p浮入,這就是capture捕獲模式,從外到內(nèi)
//
//
_divBox.addEventListener('click',function(){
    console.log('div');
},false);
document.getElementsByTagName('p')[0].addEventListener('click',function(){
   console.log('p');
},false);
//在瀏覽器中運行阳欲,點擊div會看到輸出div舵盈,點擊p會看到先輸出p然后輸出div陋率,這就是冒泡模式,從內(nèi)到外
//也是addEventListener的默認(rèn)模式秽晚,通常情況下也是用默認(rèn)冒泡模式瓦糟,使用capture模式的情況比較少。

  • onmousedown-onmouseup 鼠標(biāo)左鍵按下和抬起事件赴蝇,他倆是onclick的前奏菩浙,執(zhí)行完這倆家伙才會搭理click事件,同樣會有屬性和監(jiān)聽兩種方式句伶,這里就用屬性舉例吧~
_divBox.onmousedown = function(){
    this.style.background = '#0000FF';
}
_divBox.onmouseup = function(){
    this.style.background = '#FF0000';
}

  • onkeypress 當(dāng)按鍵按下并且被松開觸發(fā)
//這個例子比較簡單劲蜻,不用我們借用任何元素
window.onkeypress = function(){
    console.log(e.key);
}
//打開調(diào)試工具,隨便按鍵盤考余,看看效果吧

  • 其他事件事件
事件名稱 含義
onmouseover 當(dāng)鼠標(biāo)移到元素上去時
onmouseout 當(dāng)鼠標(biāo)移出元素時
onmousemove 當(dāng)鼠標(biāo)移動時
onsubmit 表單提交事件
onchange 當(dāng)元素值改變時先嬉,常用在input[text/password]/select等
onfocus 當(dāng)光標(biāo)在該元素上時/獲取焦點時
onblur 當(dāng)失去焦點時
ondblclick 當(dāng)雙擊元素時
onresize 當(dāng)元素大小有變化時,常用在screen或window
onselect 當(dāng)對象中的文本被選擇時觸發(fā)
onkeydown 當(dāng)按鍵被按下
onkeyup 當(dāng)按鍵被松開時觸發(fā)

  • 說了這么多為元素綁定事件楚堤,如果想把某個元素的事件剔除了疫蔓,那就用到這個屬性了removeEventListener
//這里需要對上面的addEventListener做個修改
function handle(){
    this.style.background='#0000ff';
}
_divBox.addEventListener('click',handle);
_divBox.removeEventListener('click',handle);
//如果沒有handle的話是沒有辦法實現(xiàn)的。身冬。衅胀。總是感覺有點坑
  • 當(dāng)然酥筝,還有另一個方法就是
//該方法僅適用于通過屬性定義的滚躯,想移除用addEventListener綁定的還是用上面的方法吧
_divBox.onclick=function(){
 //TODO
}
_divBox.onclick=null;//是不是很簡單

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市嘿歌,隨后出現(xiàn)的幾起案子掸掏,更是在濱河造成了極大的恐慌,老刑警劉巖搅幅,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件阅束,死亡現(xiàn)場離奇詭異呼胚,居然都是意外死亡茄唐,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進店門蝇更,熙熙樓的掌柜王于貴愁眉苦臉地迎上來沪编,“玉大人,你說我怎么就攤上這事年扩∫侠” “怎么了?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵厨幻,是天一觀的道長相嵌。 經(jīng)常有香客問我腿时,道長,這世上最難降的妖魔是什么饭宾? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任批糟,我火速辦了婚禮,結(jié)果婚禮上看铆,老公的妹妹穿的比我還像新娘徽鼎。我一直安慰自己,他們只是感情好弹惦,可當(dāng)我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布否淤。 她就那樣靜靜地躺著,像睡著了一般棠隐。 火紅的嫁衣襯著肌膚如雪石抡。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天助泽,我揣著相機與錄音汁雷,去河邊找鬼。 笑死报咳,一個胖子當(dāng)著我的面吹牛侠讯,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播暑刃,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼厢漩,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了岩臣?” 一聲冷哼從身側(cè)響起溜嗜,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎架谎,沒想到半個月后炸宵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡谷扣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年土全,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片会涎。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡裹匙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出末秃,到底是詐尸還是另有隱情概页,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布练慕,位于F島的核電站惰匙,受9級特大地震影響技掏,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜项鬼,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一零截、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧秃臣,春花似錦涧衙、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至稚虎,卻和暖如春撤嫩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蠢终。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工序攘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人寻拂。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓程奠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親祭钉。 傳聞我的和親對象是個殘疾皇子瞄沙,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,860評論 2 361

推薦閱讀更多精彩內(nèi)容