当前位置:
首页 >
前端技术
> 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