JS3-高级事件
获取事件和处理事件的第二种方式:事件监听
如何获取和处理鼠标与键盘的基本事件?
事件监听方式
eventTarget.addEventListener(type,listener[,useCapture])
- type:事件类型 如click
- listener:事件处理函数
- useCapture:布尔值
ie9以前的版本支持
eventTarget.attachEvent()将制定的监听器注册到eventTarget上,当对象触发指定事件时,指定的回调函数就会执行
该方法接收两个参数:
- eventNameWithOn:事件类型字符串 如onclick
- callback:事件处理函数,
删除事件
- 传统方式
eventTarget.onclick=null;
- 方法监听注册方式
eventTarget.removeEventListener(type,listener[,useCapture]);
DOM事件流
事件流描述的是从页面中接收事件 的顺序
事件发生时会在元素节点之间按照特定的顺序传播,这个传播过程即DOM事件流
DOM事件流分为3个阶段:
- 捕获阶段 自顶向下
- 当前目标阶段
- 冒泡阶段 从下往上
JS代码只能执行捕获或者冒泡其中一个阶段
onclick和attachment只能得到冒泡阶段
addEventListener第三个参数如果是true,表示在事件捕获阶段调用事件处理程序,如果是false表示在事件冒泡阶段调用
事件对象
div.onclick=function(event) {}
- event就是一个事件对象,写到我们的侦听函数里的小括号里面,当形参来看
- 事件对象只有有了事件才会存在,它是系统给我们自动创建的,不需要我们传递参数
- 事件对象使我们事件的一系列相关数据的集合 跟事件相关的 比如鼠标点击里面就包含了鼠标的相关信息如鼠标坐标等
- 事件对象可以自己命名 如evt、e、
- 有兼容性问题 ie678通过window.event获取事件对象
事件对象常见属性和方法
a.target 返回触发事件的对象(点了谁返回谁) 标准 this返回的是绑定事件的对象
a.currentTarget和this一样,但是只适用于ie9以上(了解即可)
e.srcElement 返回触发事件的对象 非标准 ie6-8常用
e.type 返回事件的类型
- 阻止默认事件 有时候需要阻止链接跳转
a.returnValue; //ie678阻止默认事件的方法 也可以直接用
a.preventDefault(); //阻止默认事件 可以让链接不跳转
return false; //阻止事件跳转(无兼容性问题)
- 冒泡会导致当多个盒子重叠并同时监听时,由于冒泡原理会一层一层执行,因此有时需要考虑阻止冒泡
a.cancelBubble=true; //非标准
a.stopPropagation(); //重点,标准写法,有兼容性问题
事件委托
事件冒泡本身的特性,会带来坏处,也会带来好处,需要我们灵活掌握。
事件委托也称为事件代理,在jQuery里称为事件委派
不要给每个子节点单独设置事件监听器,而是事件监听器设置在其父节点上,然后利用冒泡原理影响设置每个子节点
例如ul里有很多个li都需要监听事件,可以给ul设定监听器,因为点击li,事件会冒泡到ul上,就会触发事件监听器,可以利用对象的target找到当前点击的li
可以实现找到这个li后改变它的背景颜色,大大简化了代码
作用:
只操作了一次DOM,提高了程序的性能
常用的鼠标事件
鼠标事件
click:单击事件
dblclick:双击事件
mousedown:按下鼠标键时触发
mouseup:释放按下的鼠标键时触发
mousemove:鼠标移动事件
mouseover:移入事件
mouseout:移出事件
mouseenter:移入事件
mouseleave:移出事件
contextmenu:右键事件, 可以使用preventDefault禁用右键菜单
selectstart: 选中事件,可以使用selectstart禁用选中文字(不准复制~)
鼠标事件对象
现阶段主要使用鼠标事件对象和键盘事件对象
clientX,clientY永远是相对于可视窗口的坐标,不会随着滚轮拖动而改变
e.pageX、e.pageY是相对于文档页面的X、Y坐标,IE9+支持
e.screenX、e.screenY相对于电脑屏幕的X、Y坐标
常用键盘事件
键盘事件
onkeyup 某个按键松开
onkeydown 按下时
onkeypress 按下时触发,但是它不识别功能键,比如ctrl、shift、箭头
三个都写时有执行顺序区别,先执行down再执行press然后是up
键盘事件对象
key:‘1’ 直接告诉是哪个键,但是兼容性问题较大
keyCode:可以得到用户按键的ASCii码值
keyup和keydowm事件不区分字母大小写,大写和小写的ASCii码都是小写的码,而keypress区分字母大小写
案例:可以实现按键搜索框自动获取焦点
使用keyCode判断用户是否按下了s键,利用search.focus()实现搜索框获取焦点
最好用keydown判断,防止's'进入了输入框
快递单号输入内容时,上面的大盒子显示
表单检测用户输入:给表单添加键盘事件
同时把快递单号表单里的值获取过来赋值给盒子
如果快递单号里面内容为空,则隐藏盒子 con.style.display='none'
当文本框失去焦点,隐藏盒子
blur diplay=none
focus {if this.value!='' display=block}//获得焦点时还需要检测输入是否为空
注意:此处应该使用keyup,弹起时文字已经在文本框出现了 keydown和keypress触发的时候,文本框的字还没有出现,并不能实现同时放大的效果
JS3-高级事件的更多相关文章
- Jquery10 高级事件
学习要点: 1.模拟操作 2.命名空间 3.事件委托 4.on.off 和 one jQuery 不但封装了大量常用的事件处理,还提供了不少高级事件方便开发者使用.比如模拟用户触发事件.事件委托事件. ...
- 第一百七十一节,jQuery,高级事件,模拟操作,命名空间,事件委托,on、off 和 one
jQuery,高级事件,模拟操作,命名空间,事件委托,on.off 和 one 学习要点: 1.模拟操作 2.命名空间 3.事件委托 4.on.off 和 one jQuery 不但封装了大量常用的事 ...
- 第十篇 Integration Services:高级事件行为
本篇文章是Integration Services系列的第十篇,详细内容请参考原文. 简介在前一篇, we introduced fault tolerance by examining method ...
- [译]Stairway to Integration Services Level 10 - 高级事件活动
介绍 在前一篇文章中我们介绍了故障容差相关的 MaximumErrorCount 和 ForceExecutionResult 属性. 同时我们学习了SSIS Control Flow task e ...
- Js高级 事件冒泡
什么叫事件冒泡 当给父子元素的同一事件绑定方法时,触发了子元素身上的事件,执行完毕之后,也会触发父级元素的相同事件,这种传播机制叫事件冒泡. 取消事件冒泡 Event对象有个属性叫cancelBubb ...
- Js高级 事件 对象
1.事件 浏览器客户端上客户触发的行为都成为事件 所有的事件都是天生自带的,不需要我们我去绑定,只需要我们去触发. 通过obj.事件名=function(){} 事件名:onmouseover onm ...
- 【译】第十篇 Integration Services:高级事件行为
本篇文章是Integration Services系列的第十篇,详细内容请参考原文. 简介在前一篇, we introduced fault tolerance by examining method ...
- jQuery事件篇---高级事件
内容提纲: 1.模拟操作 2.命名空间 3.事件委托 4.on.off 和 one 发文不易,转载请注明出处! 一.模拟操作 在事件触发的时候,有时我们需要一些模拟用户行为的操作.例如:当网页加载完毕 ...
- 译:DOM2中的高级事件处理(转)
17.2. DOM2中的高级事件处理(Advanced Event Handling with DOM Level 2) 译自:JavaScript: The Definitive Gu ...
- 【Swing】理解Swing中的事件与线程
talk is cheap , show me the code. Swing中的事件 事件驱动 所有的GUI程序都是事件驱动的.Swing当然也是. GUI程序不同于Command Line程序,一 ...
随机推荐
- Midjourney|文心一格prompt教程[Text Prompt(下篇)]:游戏、实物、人物、风景、动漫、邮票、海报等生成,终极模板教学
Midjourney|文心一格prompt教程[Text Prompt(下篇)]:游戏.实物.人物.风景.动漫.邮票.海报等生成,终极模板教学 场景6:游戏 Prompt 真的越长越好吗? 按照 Mi ...
- 7.0 Python 面向对象编程
python是一种面向对象的编程语言,面向对象编程(Object-Oriented Programming,OOP)是一种编程思想,其核心概念是"对象".对象是指一个具有特定属性和 ...
- OpenSSH 服务配置与管理
SSH 是一种以安全的方式提供远程登陆的协议,也是目前远程管理Linux系统的首选方式,SSH由IETF的网络小组所制定,SSH为建立在应用层基础上的安全协议,SSH是目前较可靠,专为远程登录会话和其 ...
- 从嘉手札<2023-11-01>
最近心态不好,如同此刻的天气,浓雾扰扰,看不见前途未来,也想不起过去. 一则是研究没有进展,二则是感情纷扰,其实再多的纷扰也都不过是自己内心的那层桎梏,可人不能总能保持理性的: 就像很多快乐的事情是简 ...
- Vite4+Typescript+Vue3+Pinia 从零搭建(2) - ts配置
项目代码同步至码云 weiz-vue3-template 关于tsconfig的配置字段可查看其他文档,如 typeScript tsconfig配置详解 tsconfig.json 文件修改如下: ...
- 深入浅出Java多线程(五):线程间通信
引言 大家好,我是你们的老伙计秀才!今天带来的是[深入浅出Java多线程]系列的第五篇内容:线程间通信.大家觉得有用请点赞,喜欢请关注!秀才在此谢过大家了!!! 在现代编程实践中,多线程技术是提高程序 ...
- korean doll likeness模型|Japanese-doll-likeness模型获取及使用
1.模型 之前给大家写了Mac安装stable-diffusion-webui绘制AI妹子保姆级教程,教程在下面 [奶奶看了也不会]AI绘画 Mac安装stable-diffusion-webui绘制 ...
- Hive-分区取TOP N问题
问题背景 设想你对用户在不同品类上的行为打分聚合后得到这样一个表 user_cate_score uid cate score 1 1 0.3 2 2 0.5 8 3 0.9 现在,你想将每个品类的T ...
- JS 这一次彻底理解冒泡排序
壹 ❀ 引 在面试环节中,算法总是逃不掉的一关,对于我这种非班科出生且大学不接触数学的人来说,逻辑思维方面确实较为欠缺,昨晚跟百度的同学聊到凌晨,自我感觉差距较大,受了不小打击,所以决心抓一抓算法,做 ...
- CSS浮动&定位&布局
浮动简介 浮动最早起设计出来是为了实现文字环绕图片或者文字环绕的效果,现在浮动是主流的页面布局方式之一 float:浮动属性,值可以是left.right对应向左和向右浮动 元素浮动之后的特点 脱离文 ...