當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
JavaScript学习笔记(5)
生活随笔
收集整理的這篇文章主要介紹了
JavaScript学习笔记(5)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- DOM重點核心總結
- 注冊事件兩種方式
- 事件監聽方式 addEventListener(通用)attachEvent(基本不用)
- 注冊事件兼容性解決方案(照顧不同版本瀏覽器)
- 刪除事件(解綁事件)removeEventListener(通用) detachEvent(不用)
- 刪除事件的兼容性解決方案(照顧不同版本瀏覽器)
- DOM事件流 捕獲階段[下沉階段] 冒泡階段(先捕獲,后冒泡)
- DOM事件流的代碼驗證(看捕獲階段和冒泡階段綁定的事件哪個先執行,只適用于addEventListener)
- 事件對象 event(function (e) 里面的字母可以自定義,只要后面調用一致即可)
- 事件對象常見屬性和方法
- this和e.currentTarget返回的是綁定事件的對象,e.target返回的是觸發事件的對象
- e.type得到觸發事件類型、e.preventDefault阻止鏈接跳轉(阻止默認功能)
- 阻止事件冒泡 e.stopPropagation() (高版本瀏覽器)e.cancelBubble = true(低版本瀏覽器)
- 阻止事件冒泡兼容性解決方案
- 事件委托(代理、委派)為什么需要事件委托?(利用冒泡到父節點觸發事件,減少子節點頻繁綁定觸發事件帶來的程序壓力)
- 常用鼠標事件
- 禁止鼠標右鍵菜單事件 contextmenu(右鍵菜單也叫上下文菜單)禁止選中文字事件 selectstart 用 e.preventDefault()就能禁用它們了
- 鼠標事件對象(獲取鼠標點擊時的坐標:相對用戶頁面窗口 e.clientX、e.clientY,相對整個頁面 e.pageX、e.pageY,相對屏幕 e.screenX、e.screenY)
- 鼠標事件案例:跟隨鼠標的天使(鼠標移動事件:mousemove 只要鼠標一動就能觸發事件得到實時坐標)
- 常用鍵盤事件 document.onkeyup(鍵盤彈起)document.onkeydown(鍵盤按下) document.onkeypress(鍵盤按下【不能識別特定功能鍵,如ctrl、shift、方向鍵等】)
- 鍵盤事件對象 e.keyCode 返回按鍵的Ascii碼值(document.onkeyup、document.onkeydown(不能識別大小寫) document.onkeypress(能識別大小寫))
- 案例:模擬京東按下s鍵定位到搜索框(onkeyup、focus())
- 案例:模擬京東在輸入框旁邊顯示大字號
DOM重點核心總結
注冊事件兩種方式
事件監聽方式 addEventListener(通用)attachEvent(基本不用)
注冊事件兼容性解決方案(照顧不同版本瀏覽器)
刪除事件(解綁事件)removeEventListener(通用) detachEvent(不用)
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>div {width: 100px;height: 100px;background-color: pink;}</style> </head><body><div>1</div><div>2</div><div>3</div><script>var divs = document.querySelectorAll('div');divs[0].onclick = function () {alert(11);// 1. 傳統方式刪除事件divs[0].onclick = null;}// 2. removeEventListener 刪除事件divs[1].addEventListener('click', fn) // 里面的fn 不需要調用加小括號function fn() {alert(22);divs[1].removeEventListener('click', fn);}// 3. detachEventdivs[2].attachEvent('onclick', fn1);function fn1() {alert(33);divs[2].detachEvent('onclick', fn1);}</script> </body></html>刪除事件的兼容性解決方案(照顧不同版本瀏覽器)
DOM事件流 捕獲階段[下沉階段] 冒泡階段(先捕獲,后冒泡)
DOM事件流的代碼驗證(看捕獲階段和冒泡階段綁定的事件哪個先執行,只適用于addEventListener)
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>.father {overflow: hidden;width: 300px;height: 300px;margin: 100px auto;background-color: pink;text-align: center;}.son {width: 200px;height: 200px;margin: 50px;background-color: purple;line-height: 200px;color: #fff;}</style> </head><body><div class="father"><div class="son">son盒子</div></div><script>// dom 事件流 三個階段// 1. JS 代碼中只能執行捕獲或者冒泡其中的一個階段。// 2. onclick 和 attachEvent(ie) 只能得到冒泡階段。// 3. 捕獲階段 如果addEventListener 第三個參數是 true 那么則處于捕獲階段 document -> html -> body -> father -> son// var son = document.querySelector('.son');// son.addEventListener('click', function() {// alert('son');// }, true);// var father = document.querySelector('.father');// father.addEventListener('click', function() {// alert('father');// }, true);// 4. 冒泡階段 如果addEventListener 第三個參數是 false 或者 省略 那么則處于冒泡階段 son -> father ->body -> html -> documentvar son = document.querySelector('.son');son.addEventListener('click', function () {alert('son');}, false);var father = document.querySelector('.father');father.addEventListener('click', function () {alert('father');}, false);document.addEventListener('click', function () {alert('document');})</script> </body></html>事件對象 event(function (e) 里面的字母可以自定義,只要后面調用一致即可)
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title></head><body><div>123</div><script>var div = document.querySelector('div')div.onclick = function (event) {console.log(event)}</script> </body></html>
通常不用做兼容性處理,直接照下面這樣寫就好了
事件對象常見屬性和方法
this和e.currentTarget返回的是綁定事件的對象,e.target返回的是觸發事件的對象
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>div {width: 100px;height: 100px;background-color: pink;}</style> </head><body><div>123</div><ul><li>abc</li></ul><script>// 常見事件對象的屬性和方法// 1. e.target 返回的是觸發事件的對象(元素) this 返回的是綁定事件的對象(元素)// 區別 : e.target 點擊了那個元素,就返回那個元素 this 那個元素綁定了這個點擊事件,那么就返回誰var div = document.querySelector('div');div.addEventListener('click', function (e) {console.log(e.target);console.log(this);})var ul = document.querySelector('ul');ul.addEventListener('click', function (e) {// 我們給ul 綁定了事件 那么this 就指向ul console.log(this);console.log(e.currentTarget);// e.target 指向我們點擊的那個對象 誰觸發了這個事件 我們點擊的是li e.target 指向的就是liconsole.log(e.target);})// 了解兼容性// div.onclick = function(e) {// e = e || window.event;// var target = e.target || e.srcElement;// console.log(target);// }// 2. 了解 跟 this 有個非常相似的屬性 currentTarget ie678不認識</script> </body></html>e.type得到觸發事件類型、e.preventDefault阻止鏈接跳轉(阻止默認功能)
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style></style> </head><body><div>123</div><a href="http://www.baidu.com">百度</a><form action="http://www.baidu.com"><input type="submit" value="提交" name="sub"></form><script>// 常見事件對象的屬性和方法// 1. 返回事件類型var div = document.querySelector('div');div.addEventListener('click', fn);div.addEventListener('mouseover', fn);div.addEventListener('mouseout', fn);function fn(e) {console.log(e.type);}// 2. 阻止默認行為(事件) 讓鏈接不跳轉 或者讓提交按鈕不提交var a = document.querySelector('a');a.addEventListener('click', function (e) {e.preventDefault(); // dom 標準寫法})// 3. 傳統的注冊方式a.onclick = function (e) {// 普通瀏覽器 e.preventDefault(); 方法// e.preventDefault();// 低版本瀏覽器 ie678 returnValue 屬性// e.returnValue;// 我們可以利用return false 也能阻止默認行為 沒有兼容性問題 特點: return 后面的代碼不執行了, 而且只限于傳統的注冊方式return false;alert(11);}</script> </body></html>阻止事件冒泡 e.stopPropagation() (高版本瀏覽器)e.cancelBubble = true(低版本瀏覽器)
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>.father {overflow: hidden;width: 300px;height: 300px;margin: 100px auto;background-color: pink;text-align: center;}.son {width: 200px;height: 200px;margin: 50px;background-color: purple;line-height: 200px;color: #fff;}</style> </head><body><div class="father"><div class="son">son兒子</div></div><script>// 常見事件對象的屬性和方法// 阻止冒泡 dom 推薦的標準 stopPropagation() var son = document.querySelector('.son');son.addEventListener('click', function(e) {alert('son');e.stopPropagation(); // stop 停止 Propagation 傳播e.cancelBubble = true; // 非標準 cancel 取消 bubble 泡泡}, false);var father = document.querySelector('.father');father.addEventListener('click', function() {alert('father');}, false);document.addEventListener('click', function() {alert('document');})</script> </body></html>阻止事件冒泡兼容性解決方案
事件委托(代理、委派)為什么需要事件委托?(利用冒泡到父節點觸發事件,減少子節點頻繁綁定觸發事件帶來的程序壓力)
常用鼠標事件
禁止鼠標右鍵菜單事件 contextmenu(右鍵菜單也叫上下文菜單)禁止選中文字事件 selectstart 用 e.preventDefault()就能禁用它們了
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title> </head><body>我是一段不愿意分享的文字<script>// 1. contextmenu 我們可以禁用右鍵菜單document.addEventListener('contextmenu', function(e) {e.preventDefault();})// 2. 禁止選中文字 selectstartdocument.addEventListener('selectstart', function(e) {e.preventDefault();})</script> </body></html>鼠標事件對象(獲取鼠標點擊時的坐標:相對用戶頁面窗口 e.clientX、e.clientY,相對整個頁面 e.pageX、e.pageY,相對屏幕 e.screenX、e.screenY)
鼠標事件案例:跟隨鼠標的天使(鼠標移動事件:mousemove 只要鼠標一動就能觸發事件得到實時坐標)
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>img {position: absolute;top: 2px;}</style> </head><body><img src="蜥蜴女仆.gif" alt=""><script>var pic = document.querySelector('img');document.addEventListener('mousemove', function (e) {// 1. mousemove只要我們鼠標移動1px 就會觸發這個事件// console.log(1);// 2.核心原理: 每次鼠標移動,我們都會獲得最新的鼠標坐標, 把這個x和y坐標做為圖片的top和left 值就可以移動圖片var x = e.pageX;var y = e.pageY;console.log('x坐標是' + x, 'y坐標是' + y);//3 . 千萬不要忘記給left 和top 添加px 單位pic.style.left = x - 50 + 'px';pic.style.top = y - 40 + 'px';});</script> </body></html>常用鍵盤事件 document.onkeyup(鍵盤彈起)document.onkeydown(鍵盤按下) document.onkeypress(鍵盤按下【不能識別特定功能鍵,如ctrl、shift、方向鍵等】)
<!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title> </head><body><div>鍵盤事件</div><script>// 常用的鍵盤事件//1. keyup 按鍵彈起的時候觸發 // document.onkeyup = function() {// console.log('我彈起了');// }document.addEventListener('keyup', function () {console.log('我彈起了');})//3. keypress 按鍵按下的時候觸發 不能識別功能鍵 比如 ctrl shift 左右箭頭啊document.addEventListener('keypress', function () {console.log('我按下了press');})//2. keydown 按鍵按下的時候觸發 能識別功能鍵 比如 ctrl shift 左右箭頭啊document.addEventListener('keydown', function () {console.log('我按下了down');})// 4. 三個事件的執行順序 keydown -- keypress -- keyup</script> </body></html>鍵盤事件對象 e.keyCode 返回按鍵的Ascii碼值(document.onkeyup、document.onkeydown(不能識別大小寫) document.onkeypress(能識別大小寫))
案例:模擬京東按下s鍵定位到搜索框(onkeyup、focus())
案例:模擬京東在輸入框旁邊顯示大字號
總結
以上是生活随笔為你收集整理的JavaScript学习笔记(5)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JavaScript学习笔记(4)
- 下一篇: JavaScript学习笔记(6)BOM