1、焦點:當一個元素有焦點的時候,那麼他就可以接受用戶的輸入(不是所有元素都能接受焦點)
給元素設置焦點的方式:
1、點擊
2、tab
3、js
2、(例子:輸入框提示文字)
onfocus:當元素獲取焦點時觸發:
element.onfocus = function(){};
onblur:當元素失去焦點時觸發:
element.onblur = function(){};
obj.focus() 給指定的元素設置焦點
obj.blur() 取消指定元素的焦點
obj.select()選擇指定元素裡面的文本內容
3、(例子:方塊隨著鼠標移動)
event: 事件對象。
當一個事件發生時,和當前這個對象發生的事件所有有關的信息都會臨時保存在一個指定的地方-event對象,供我們需要時調用。就像是飛機的黑匣子。
事件對象必須在一個對象的事件調用函數中使用才有內容。
事件函數:事件調用的函數,一個函數是不是事件函數,不在定義時決定而是在調用的時候決定
4、兼容
element.onclick = fn1;
IE/Chrome浏覽器:event是一個內置的全局對象(可以直接使用)
function fn1(){ alert(event); }
標准下:事件對象是通過事件函數的第一個參數傳入
function fn1(ev){ alert(ev); }
兼容寫法:
function fn1(ev){ var ev = ev || event; }
clientX[Y]:當一個事件發生的時候,鼠標到頁面可視區的距離
5、事件流(例子:仿select控件)
● 事件冒泡:當一個元素接受到事件的時候,會把他接受到的事件傳播給他的父級,一直到頂層window。
● 事件捕獲:一個元素要想接受到事件,它的父元素會首先接受到該事件,然後再傳給它。
注意:在ie下是沒有的事件捕獲的。在事件綁定中,標准下有
6、事件綁定
● 第一種:
element.onclick = fn1;
注意:oDiv.onclick = fn1;
oDiv.onclick = fn2;
這樣fn2會覆蓋fn1;
● 第二種:
IE:obj.attachEvent(事件名稱,事件函數)
1、沒有捕獲
2、事件名稱有on
3、事件函數的執行順序:標准》正序 非標准》倒序
4、this指向window
element.attachEvent(onclick,fn1);
標准:obj.addEventListener(事件名稱,事件函數,是否捕獲)
1、有捕獲
2、事件名稱沒有on
3、事件的執行順序是正序
4、this指向觸發該事件的對象
element.addEventListener(click,fn1,false);
bind函數
function bind(obj,evname,fn){ if(obj.addEventListener){ obj.addEventListener(evname,fn,false); }else{ obj.attachEvent('on' + evname,function(){ fn.call(obj); }); } }
事件取消綁定
● 第一種
element.onclick = null;
● 第二種
IE:obj.detachEvent(事件名稱,事件函數);
document.detachEvent('onclick',fn1);
標准:obj.removeEventListener(事件名稱,事件函數,是否捕獲);
document.removeEventListener('click',fn1,false);
8、鍵盤事件(例子:留言本)
● onkeydown : 當鍵盤按鍵按下的時候觸發
● onkeyup : 當鍵盤按鍵抬起的時候觸發
● event.keyCode : 數字類型 鍵盤按鍵的值 鍵值
ctrlKey,shiftKey,altKey布爾值
當一個事件觸發的時候,如果shift || ctrl || alt鍵沒有按下,則返回false,否則返回true;
9、默認事件(例子:自定義右鍵菜單、鍵盤控制div運動)
● 事件默認行為 : 當一個事件發生的時候浏覽器默認會做的事。
● 阻止默認事件:return false;
oncontextmenu : 右鍵菜單事件,當右鍵菜單(環境菜單)顯示出來的時候觸發。
案例:
方塊隨著鼠標移動:
onmouseover:當鼠標在一個元素上移動時觸發
注意:觸發的頻率不是像素,而是間隔時間。在一個間隔時間內不論鼠標移動了多遠只觸發一次
<style> body{ height: 2000px; } #div{ width:100px; height: 100px; background:red; position: absolute; } </style> <body> <div id="div1"></div> </body> <script> var oDiv = document.getElementById('div1'); document.onmouseover = function(ev){ var ev = ev || event; // 如果當滾動條滾動了(頁面的頭部部分隱藏了),方塊是以頁面定位的,而鼠標是以可視區定位的,這樣就會產生bug。所以我們要加上滾動條滾動的距離 var scrollTop = document.documentElement.scrollTop || document.body.scrollTop; oDIv.style.top = ev.clientX + scrollTop + 'px'; oDIv.style.left = ev.clientY + 'px'; } </script>
輸入框文字提示:
<style></style> <body> <input type="text" id="text1" value="請輸入內容"/> <input type="button" id="btn" value="全選" /> </body> <script> var oText = document.getElementById('text1'); var oBtn = document.getElementById('btn'); oText.onfocus = function(){ if(this.value == '請輸入內容'){ this.value = ''; } } oText.onblur = function(){ if(this.value == ''){ this.value = '請輸入內容'; } } oBtn.onclick = function(){ oText.select(); } </script>
仿select控件:
<style> #div1{ width: 100px; height: 200px; border: 1px solid red; display: none; } </style> <body> <input type="button" value="按鈕" id="btn" /> <div id="div1"></div> <p>ppppppppp</p> <p>ppppppppp</p> <p>ppppppppp</p> <p>ppppppppp</p> <p>ppppppppp</p> </body> <script> window.onload = function(){ var oBtn = document.getElementById('btn'); var oDiv = document.getElementById('div1'); oBtn.onclick = function(ev){ var ev = ev || event; ev.cancelBubble = true; oDiv.style.display = 'block'; } document.onclick = function(){ oDiv.style.display = 'none'; } } </script>
留言本:
<style></style> <body> <input type="text" id="con"/> <ul id="box"></ul> </body> <script> var oUl = document.getElementById('box'); var oText = document.getElementById('con'); document.onkeyup = function(ev){ var ev = ev || even; if(ev.keyCode != ''){ if(ev.keyCode == 13){ var oLi = document.createElement('li'); oLi.innerHTML = oText.value; if(oUl.children[0]){ oUl.insertBefore(oLi,oUl.children[0]); }else{ oUl.appendChild(oLi); } } } } </script>
自定義右鍵菜單:
<style> body{ height: 2000px; } #box{ width: 100px; height: 200px; background: red; display: none; position: absolute;; } </style> <body> <div id="box"></div> </body> <script> var oBox = document.getElementById('box'); document.oncontextmenu = function(ev){ var ev = ev || event; var scrollTop = document.documentElement.scrollTop || document.body.scrollTop; var scrollLeft = document.documentElement.scrollLeft || document.body.scrollLeft; oBox.style.display = 'block'; oBox.style.top = scrollTop + ev.clientY + 'px'; oBox.style.left = scrollLeft + ev.clientX + 'px'; return false; } document.onclick = function(){ oBox.style.display = 'none'; } </script>
鍵盤控制div運動:
<style> #box{ width: 100px; height: 100px; background: red; position: absolute; } </style> <body> <div id="box"></div> </body> <script> var oBox = document.getElementById('box'); var timer = null; var oLeft = false; var oTop = false; var oRight = false; var oBottom = false; // 運動一直就緒,等待按鍵操作 timer = setInterval(function(){ if(oLeft){ oBox.style.left = oBox.offsetLeft - 10 + 'px'; }else if(oTop){ oBox.style.top = oBox.offsetTop - 10 + 'px'; }else if(oRight){ oBox.style.left = oBox.offsetLeft + 10 + 'px'; }else if(oBottom){ oBox.style.top = oBox.offsetTop + 10 + 'px'; } // 防止溢出 limit(); },10); // 按鍵按下,開始運動 document.onkeydown = function(ev){ var ev = ev || even; switch (ev.keyCode){ case 37: oLeft = true; break; case 38: oTop = true; break; case 39: oRight = true; break; case 40: oBottom = true; break; } } // 按鍵抬起,停止運動 document.onkeyup = function(ev){ var ev = ev || even; switch (ev.keyCode){ case 37: oLeft = false; break; case 38: oTop = false; break; case 39: oRight = false; break; case 40: oBottom = false; break; } } function limit(){ // 控制左邊 if(oBox.offsetLeft <= 0){ oBox.style.left = 0; } // 控制上邊 if(oBox.offsetTop <= 0){ oBox.style.top = 0; } // 控制右邊 if(document.documentElement.clientWidth - oBox.offsetLeft - oBox.offsetWidth < 0){ oBox.style.left = document.documentElement.clientWidth - oBox.offsetWidth + 'px'; } // 控制下邊 if(document.documentElement.clientHeight - oBox.offsetTop - oBox.offsetHeight < 0){ oBox.style.top = document.documentElement.clientHeight - oBox.offsetHeight + 'px'; } } </script>
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持!