1.每一个元素身上的事件都是天生自带的,不需要我们去定义,只需要我们给这个事件绑定的方法,当事件触发的时候就会执行这个方法。

2.事件绑定的方法

  1,div.onclick=function(){}    Dom0级事件绑定

  2,div.addEventListener()或div.attachEvent()     Dom2级事件绑定

  二者的区别

  onclick是这个元素私有的属性,天生自带的,而addEventListener()是公有的属性,从EventTarget(事件源)对象上继承来的。

  Ie低版本的attachEvent是公有的。

  div.onclick存在事件冒泡机制没有捕获机制

  div.addEventListener()可有冒泡可有捕获

  div.attachEvent()只有冒泡机制

3.div.addEventListener和div.attachEvent的区别

  1.前者有冒泡和捕获机制,后者只有冒泡机制

  2.事件名前者不带on后者带on

  3.前者this指向当前元素,后者指向window

  4.前者是标准浏览器的写法,后者是ie8以下

Arguments

每个函数都有一个argument对象,他是这个函数所有参数构造的集合

上面的控制台是arguments数组中有一个元素叫mouseevent。

所有,每个事件的方法中浏览器都给他一个参数叫mouseevent。我们所有鼠标的信息都临时存储在这个mouseevent对象上。

mouseevent有兼容性

  标准浏览器可以直接读取,但是ie不行

  解决办法

event对象的兼容性

  clientX和clientY是鼠标到浏览器窗口左上角的距离坐标

  pageX和pageY是鼠标到网页左上角的距离坐标,但是ie低版本没有这个属性

  在ie下怎么算pageY的值 用clientY+scrollTop

事件源   点击那个元素,哪个元素就是事件源

  标准浏览器的事件源是ev.target

  Ie6-8没有这个属性 但是ie有ev.srcElement

阻止事件冒泡兼容性

  1       event.cancelBubble=true

  2  event.stopPropagation?event.stopPropation():event.cancelBubble=true

阻止事件默认行为兼容性

  比如a的href

  href为空 会自动刷新页面

  href为#  锚点跳转

  href为javascript:;阻止默认行为的发生

  Event.preventDefault?Event.preventDefault():event.returnValue=false

事件委托

  如果子元素身上绑定大量相同的事件,我们尽量采用事件委托,所有子元素把自己的是建委托给父级了。

  原理:采用事件冒泡机制完成

为什么使用事件委托呢

  传统的for循环绑定事件,会增加大量的dom操作(事件),影响页面性能,采用事件委托就是把所有的事件基于一个元素上

事件委托和传统的事件绑定的优势

  传统的事件绑定对新增元素不起作用,事件委托起作用

  传统的事件绑定,有多少元素js就需要绑定多少事件,事件委托只需要一个事件

案例

传统写法

事件委托写法

事件委托建议采纳

5.并不是所有的事件都存在事件冒泡

onmouseenter      onmouseleave就没有事件冒泡机制

所有我们做跟鼠标的时候尽量用这两个事件,不要mouseover  mouseout

js高级1的更多相关文章

  1. JS高级前端开发群加群说明及如何晋级

    JS高级前端开发群加群说明 一.文章背景: 二. 高级群: 三. 加入方式: 四. 说明:   一.文章背景: 去年年初建了几个群,在不经意间火了,一直排在“前端开发”关键字搜索结果第一名.当然取得这 ...

  2. 前端进阶试题css(来自js高级前端开发---豪情)既然被发现了HOHO,那我就置顶了嘿嘿!觉得自己技术OK的可以把这套题目做完哦,然后加入高级前端的社区咯

    http://www.cnblogs.com/jikey/p/4426105.html js高级前端开发加群方法(此群很难进,里面纯技术,严禁广告,水群) 完整题目做完发邮箱(jikeytang@16 ...

  3. Node.js高级编程读书笔记Outline

    Motivation 世俗一把,看看前端的JavaScript究竟能做什么. 顺便检验一下自己的学习能力. Audience 想看偏后台的Java程序员关于前端JavaScript的认识的职业前端工程 ...

  4. 读JS高级——第五章-引用类型 _记录

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. js高级程序设计笔记之-addEventListener()与removeEventListener(),事件解除与绑定

    js高级程序设计笔记之-addEventListener()与removeEventListener(),事件解除与绑定 addEventListener()与removeEventListener( ...

  6. 《JS高级程序设计》笔记 —— 解析查询字符串

    今天在继续翻阅<JS高级程序设计>的时候,正好翻到location对象这一小节,其中有一部分就是讲的解析查询字符串.看到这个内容立马想到了做去哪儿秋招笔试题的时候有这么一道题. 去哪儿笔试 ...

  7. js 高级函数 之示例

    js 高级函数作用域安全构造函数 function Person(name, age)    {        this.name = name;        this.age = age;     ...

  8. 惰性函数——JS高级

    我们先来看一下js的异步提交. XHR我们在原生的时候常常用到,因为常用到,我们更多把封装到了工具库中 先看下他最常用的实现 // 旧方法 function createXHR() { var xhr ...

  9. 《Node.js 高级编程》简介与第二章笔记

    <Node.js 高级编程> 作者简介 Pedro Teixerra 高产,开源项目程序员 Node 社区活跃成员,Node公司的创始人之一. 10岁开始编程,Visual Basic.C ...

  10. js高级-面向对象继承

    一.工厂模式创建对象及优缺点 继承就是把公共的部分抽象出来作为父类,基类.吃饭,跑步等 var a = {}; //批量创建不方便,不能重复设置公共属性的代码 //工厂模式出现了,创建10个Cat对象 ...

随机推荐

  1. django中的一对一、一对多、多对多及ForeignKey()

    参考文章: Django ORM.一对一.一对多.多对多.详解 刘江的博客——关系类型字段 问题: OneToOneField()与ForeignKey()的区别及其使用场景

  2. Coursera, Big Data 3, Integration and Processing (week 1/2/3)

    This is the 3rd course in big data specification courses. Data model reivew 1, data model 的特点: Struc ...

  3. Shell 自动化部署免密登录

    1 .配置主机名称 参考:Linux 修改主机名 和 ip 映射关系 2 . 编写脚本 root.sh 内容 #!/bin/bash SERVERS="hadoop0 hadoop1 had ...

  4. Emmet(以前的Zencoding)的使用

    Emmet就是以前的Zencoding div.wrapper#wrapper>div.right+div.left*2>span{nimei$}*3 //. 类名 #id >下面 ...

  5. laravel5.4 向闭合函数内部传递参数

    laravel  向闭合函数内部传入参数

  6. Find K Closest Elements

    Given a sorted array, two integers k and x, find the k closest elements to x in the array. The resul ...

  7. torch.utils.data.DataLoader()中的pin_memory参数

    参考链接:http://www.voidcn.com/article/p-fsdktdik-bry.html 该pin_memory参数与锁页内存.不锁页内存以及虚拟内存三个概念有关: 锁页内存理解( ...

  8. JAVA中的栈和堆【转】

    原文链接 https://www.cnblogs.com/ibelieve618/p/6380328.html JAVA在程序运行时,在内存中划分5片空间进行数据的存储.分别是:1:寄存器.2:本地方 ...

  9. JavaScript入门学习笔记(二)

    JavaScript运算符: 算术运算符.赋值运算符和字符串连接运算符. 算法运算符与复制运算符用法参照Java: 字符串运算符: +运算符用于把文本值或字符串变量连接起来,适用于两个或更多字符串变量 ...

  10. 库数据有则修改,无则新增sql

    方法一:insert中on duplicate key update的使用 例如: <insert id="bindPlaceInfo"> insert into gr ...