中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

javascript 鼠標事件總結(jié)

常見的有以下8個:
mousedown:鼠標的鍵鈕被按下。
mouseup:鼠標的鍵鈕被釋放彈起。
click:單擊鼠標的鍵鈕。
dblclick:鼠標的鍵鈕被按下。
contextmenu :彈出右鍵菜單。
mouseover:鼠標移到目標的上方。
mouseout:鼠標移出目標的上方。
mousemove:鼠標在目標的上方移動
mousedown事件與mouseup事件可以說click事件在時間上的細分,順序是mousedown => mouseup => click。因此一個點擊事件,通常會激發(fā)幾個鼠標事件。


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
有了它們,我們可以做許多事,但對于高層次的應(yīng)用(如游戲)是顯然不夠的,于是鼠標事件的點擊事件又根據(jù)究竟是點左鍵還是右鍵進行細分。在DOM2.0中,W3C對鼠標事件作了現(xiàn)范,鼠標事件被解析為MouseEvent(我們可以用e.constructor == MouseEvent來判斷其是否為鼠標事件,是左鍵點擊還是右鍵點擊由它的一個叫button的屬性判定。以下就是W3C的標準現(xiàn)范:

0:按下左鍵
1:按下中鍵(如果有的話)
2:按下右鍵
當然微軟是不會妥協(xié)的,因為e.button本來就是微軟最先實現(xiàn)的,網(wǎng)景用的是e.which,但相對而言,微軟的復雜多了。

0:沒有鍵被按下
1:按下左鍵
2:按下右鍵
3:左鍵與右鍵同時被按下
4:按下中鍵
5:左鍵與中鍵同時被按下
6:中鍵與右鍵同時被按下
7:三個鍵同時被按下
更詳細的情況見下表。
GE:Gecko ;SA:Safari; OP:Opera; NS:NETscape

IENS 4GE ≥ 1.0
SA 3
OP ≥ 8.0
GE0.9OP<8.0
e.button左鍵1undefined011
中鍵4undefined123
右鍵2undefined232
e.which左鍵undefined1111
中鍵undefined2223
右鍵undefined3332
為此我們可以使用以下函數(shù)來綁定左右鍵。
復制代碼 代碼如下:
var mouseEvent = function(){
var arg = arguments[0],
el = arg.el || document,
leftfn = arg.left || function(){},
rightfn = arg.right || function(){},
middlefn = arg.middle || function(){},
buttons = {};
el.onmousedown = function(e){
e = e || window.event;
if(!+"/v1"){
switch(e.button){
case 1:buttons.left = true; break;
case 2:buttons.right = true; break;
case 4:buttons.middle = true; break;
}
}else{
switch(e.which){
case 1:buttons.left = true;break;
case 2:buttons.middle = true; break;
case 3:buttons.right = true;break;
}
}
if(buttons.left){
leftfn();
}else if(buttons.middle){
middlefn();
}else if(buttons.right){
rightfn();
}
buttons = {
"left":false,
"middle":false,
"right":false
};
}
}

它接受一個哈希參數(shù),都是可選項。哈希的el為要綁定鼠標事件的元素,left為點擊左鍵激發(fā)的事件,其他兩個類推。用法如下:
復制代碼 代碼如下:
var el = document.getElementById("mouse");
var ex = document.getElementById("explanation");
var left = function(){
ex.innerHTML = "左鍵被按下";
}
var right = function(){
ex.innerHTML = "右鍵被按下";
}
mouseEvent({el:el,left:left,middle:null,right:right});


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
此外,通過鼠標在網(wǎng)頁上的點擊,我們還可以獲得許多有用的參數(shù),如獲得當前鼠標的坐標。根據(jù)其參照物的不同,分為以下幾套坐標系。一套是以當前瀏覽器的可視區(qū)為參照物(clientX, clientY),另一套是以顯示器的屏幕為參照物(screenX, screenY)。此外微軟還有一套坐標系(x,y),它是相對于觸發(fā)事件的對象的offsetParent的,火狐有另一套坐標系(pageX, pageY),它是相對于當前網(wǎng)頁的。我們可以通過如下函數(shù)來獲得鼠標在網(wǎng)頁的坐標。
復制代碼 代碼如下:
var getCoordInDocument = function(e) {
e = e || window.event;
var x = e.pageX || (e.clientX +
(document.documentElement.scrollLeft
|| document.body.scrollLeft));
var y= e.pageY || (e.clientY +
(document.documentElement.scrollTop
|| document.body.scrollTop));
return {'x':x,'y':y};
}


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
clientXY
(clientX,clientY)的坐標系,不受滾動條影響
至于mouseover,mousemove,mouseout沒有什么好說,并且無瀏覽器差異。我們來看鼠標滾輪事件,這個差異很嚴重。IE、Safari、 Opera 、chrome是mousewheel事件,F(xiàn)irefox是DOMMouseScroll事件。事件屬性方面,IE等是event. wheelDelta,F(xiàn)irefox是event. detail。IE等往上滾一圈為120,往下滾一圈為-120。Firefox往上滾一圈為-3,往下滾一圈為3。我們可以構(gòu)造一個函數(shù)來削除它們的差異。
復制代碼 代碼如下:
var mouseScroll = function(fn){
var roll = function(){
var delta = 0,
e = arguments[0] || window.event;
delta = (e.wheelDelta) ? e.wheelDelta / 120 : -(e.detail || 0) / 3;
fn(delta);//回調(diào)函數(shù)中的回調(diào)函數(shù)
}
if(/a/[-1]=='a'){
document.addEventListener('DOMMouseScroll', roll, false);
}else{
document.onmousewheel = roll;
}
}

此函數(shù)接受一函數(shù)作為參數(shù),如:
復制代碼 代碼如下:
mouseScroll(function(delta){
var obj = document.getElementById('scroll'),
current = parseInt(obj.offsetTop)+(delta*10);
obj.style.top = current+"px";
});


[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]

JavaScript技術(shù)javascript 鼠標事件總結(jié),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美日韩a | 91视频在线观看免费 | 一级欧美 | 日本aaaa| 日韩欧美国产精品 | 午夜欧美一区二区三区在线播放 | 99爱国产| 亚洲视频一区 | 国产高清免费 | 精品欧美一区二区三区免费观看 | 香蕉久久久 | 久久久久久久一区 | 亚洲一区日韩 | 成人高清视频在线观看 | 国产日韩视频 | 精品一区二区三区免费视频 | 一区二区三区国产好的精 | 韩国精品一区 | 久久午夜视频 | 亚洲 中文 欧美 日韩 在线观看 | 在线亚州| 91国内精精品久久久久久婷婷 | 国产午夜精品久久久 | 久久久久国产精品午夜一区 | 国产精品视屏 | 日韩一区二区三区在线视频 | 日本在线免费看最新的电影 | 亚洲欧美激情视频 | 亚洲欧洲国产视频 | 黄网站涩免费蜜桃网站 | av在线黄 | 日韩a视频| 久久综合久久自在自线精品自 | 亚洲人成人一区二区在线观看 | 国产精品美女久久久久aⅴ国产馆 | 另类专区亚洲 | 欧美日韩中| 69av在线视频 | 男女视频在线免费观看 | 欧美一区日韩一区 | 免费观看一级特黄欧美大片 |