热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaScript中几个主要的知识点(2)DOM事宜

JavaScript中几个最主要的大知识点面向对象DOM事宜异步交互ajax事宜事宜就是文档和浏览器的霎时交互行动1.事宜范例点击:click滚轮:scroll滑动:move进入:

Javascript中几个最主要的大知识点

  1. 面向对象

  2. DOM事宜

  3. 异步交互ajax

事宜

事宜就是文档和浏览器的霎时交互行动

1.事宜范例
  • 点击: click

  • 滚轮: scroll

  • 滑动: move

  • 进入: enter

  • 加载: load

2.事宜机制
  • 事宜的监听(事宜的绑定)

    • 经由过程on+事宜名 这类范例绑定的事宜都叫做DOM0级事宜

    • DOM0级事宜,同一个元素的同一个事宜监听,绑定的触发运转函数,不能反复绑定,有且只能绑定一回,下一次绑定的会将上一次的给覆蓋掉

    • 事宜设为null,移除事宜的监听

    • 监听事宜,不仅是浏览器的一种机制,也是浏览器给予DOM文档元素的属性,即事宜的监听是时刻存在的,然则事宜触发时刻运转的处置惩罚函数,是我们本身定义的

  • 事宜的触发:触发事宜时刻运转绑定的处置惩罚函数

JS中的事宜,实在是以一个类的情势存在的,每一个绑定的事宜实在都是这个类的一个实例 (援用数据范例的对象) ,浏览器会给我们的一切的事宜触发函数中,默许传入一个实参,就是当前事宜的事宜对象(event),在这个事宜对象中,保存着当前事宜一切信息

事宜对象存在于一切的事宜的触发处置惩罚函数中,事宜对象中有一些经常运用的属性,用于掌握交互中的结果。

  • clientX/clientY:鼠标点击点对应屏幕左上角的位置信息

  • pageX/pageY:鼠标点击的点对应body左上角的位置信息

  • keyCode:键盘事宜中键盘对应的键盘码

    • Backspace: keyCode:8 删除键

    • enter: keyCode:13 回车键

    • space: keyCode:32 空格键

    • arrowLeft/Up/Right/Down: keyCode:37 / 38 / 39 / 40 小键盘左 / 上 / 右 / 下

事宜对象还存在一些兼容性:在规范浏览器下他的事宜对象存在于当前函数的作用域中,而在ie中存在于window作用域下。

//处置惩罚事宜对象的兼容性写法
event=event|| window.event;
//处置惩罚事宜源的兼容性写法
event.target || event.srcElement
//处置惩罚事宜冒泡的兼容性写法
event.stopPropagation() || event.cancelBubble=true;
//阻挠默许行动的兼容写法
event.preventDefault() || event.returnValue=false;

3.事宜托付的头脑

有时刻我们需要对一个DOM元素下的多个子元素绑定雷同的事宜,比如说为表格增加可删除一行的功用,平常的要领是轮回绑定事宜,然则如许的方法明显机能不高,这时刻就能够只为其父元素绑定事宜,经由过程事宜托付来完成其多个子元素的雷同事宜结果。

事宜托付的道理为:依据事宜流的流传机制,我们在父级标签上监听事宜,经由过程捕捉和冒泡机制,在触发子集的事宜的时刻,冒泡流传给父级,来触发父级的事宜处置惩罚函数

那末什么是事宜得出流传机制呢?总的来说能够把事宜流的流传机制分为两到三个阶段:

  1. 事宜捕捉阶段:从DOM最外层标签HTML最先往子元素捕捉事宜源

  2. 捕捉到事宜对象(能够归到第一阶段)

  3. 冒泡流传:从捕捉到事宜源的元素最先往父级元素举行事宜冒泡,DOM0级事宜中,事宜绑定函数的触发都发生在冒泡阶段

DOM2级事宜

DOM2级事宜就是DOM0级事宜的优化,同一个文档对象同一个事宜,能够绑定多个事宜处置惩罚顺序,还能够掌握事宜处置惩罚顺序的实行阶段在捕捉或许冒泡阶段实行。

1.在规范浏览器中,绑定DOM2级事宜的要领为:addEventListener()

  • 第一个参数为事宜范例:[String] click / mouseover / blur …

  • 第二个参数为事宜处置惩罚函数:[Function] listener

  • 第三个参数为事宜处置惩罚函数是不是在冒泡阶段实行:[Boolean] ture/false

假如直接触发的是事宜源的监听事宜,没有事宜托付的情况下,则冒泡和捕捉会同时发生,此时会依据函数的誊写先后顺序实行事宜处置惩罚顺序

事宜绑定函数中的this指向当前绑定事宜的DOM对象,this还即是currentTarget。
运用 removeEventListener() 来移除事宜,参数必需与要移除的事宜处置惩罚函数地点指针雷同。

2.在低版本IE浏览器(6-8)中,绑定DOM2级事宜的要领为:attachEvent()

IE中的DOM2级事宜的事宜处置惩罚顺序,都是在冒泡阶段实行的。

  • 第一个参数为事宜范例:[String] onclick / onmouseover / onblur …

  • 第二个参数为事宜处置惩罚顺序::[Function] listener

IE下DOM2级事宜的处置惩罚函数是绑定在全局(window)下,所以其内部this指向window,IE下DOM二级事宜还存在反复实行屡次雷同的处置惩罚函数和函数实行乱序的题目,能够用 定阅 – 宣布 形式处理这些兼容性题目。
运用detachEvent()来移除事宜,参数一样必需与要移除的事宜地点指针雷同


推荐阅读
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • 本文整理了Java中org.gwtbootstrap3.client.ui.Icon.addDomHandler()方法的一些代码示例,展示了Icon.ad ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
  • JavaScript和HTML之间的交互是经由过程事宜完成的。事宜:文档或浏览器窗口中发作的一些特定的交互霎时。能够运用侦听器(或处置惩罚递次来预订事宜),以便事宜发作时实行相应的 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • 设计模式——模板方法模式的应用和优缺点
    本文介绍了设计模式中的模板方法模式,包括其定义、应用、优点、缺点和使用场景。模板方法模式是一种基于继承的代码复用技术,通过将复杂流程的实现步骤封装在基本方法中,并在抽象父类中定义模板方法的执行次序,子类可以覆盖某些步骤,实现相同的算法框架的不同功能。该模式在软件开发中具有广泛的应用价值。 ... [详细]
  • Hibernate延迟加载深入分析-集合属性的延迟加载策略
    本文深入分析了Hibernate延迟加载的机制,特别是集合属性的延迟加载策略。通过延迟加载,可以降低系统的内存开销,提高Hibernate的运行性能。对于集合属性,推荐使用延迟加载策略,即在系统需要使用集合属性时才从数据库装载关联的数据,避免一次加载所有集合属性导致性能下降。 ... [详细]
  • 本文介绍了在sqoop1.4.*版本中,如何实现自定义分隔符的方法及步骤。通过修改sqoop生成的java文件,并重新编译,可以满足实际开发中对分隔符的需求。具体步骤包括修改java文件中的一行代码,重新编译所需的hadoop包等。详细步骤和编译方法在本文中都有详细说明。 ... [详细]
  • Servlet多用户登录时HttpSession会话信息覆盖问题的解决方案
    本文讨论了在Servlet多用户登录时可能出现的HttpSession会话信息覆盖问题,并提供了解决方案。通过分析JSESSIONID的作用机制和编码方式,我们可以得出每个HttpSession对象都是通过客户端发送的唯一JSESSIONID来识别的,因此无需担心会话信息被覆盖的问题。需要注意的是,本文讨论的是多个客户端级别上的多用户登录,而非同一个浏览器级别上的多用户登录。 ... [详细]
  • 颜色迁移(reinhard VS welsh)
    不要谈什么天分,运气,你需要的是一个截稿日,以及一个不交稿就能打爆你狗头的人,然后你就会被自己的才华吓到。------ ... [详细]
author-avatar
手机用户2502856553
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有