一 .  焦点:使浏览器能够区分区分用户输入的对象,当一个元素有焦点的时候,那么他就可以接收用户的输入。

我们可以通过一些方式给元素设置焦点

1.点击 2.tab   3.js

不是所有元素都能够接受焦点的,能够响应用户操作的元素才有焦点(比如:输入框,可以响应用户的输入 按钮-可以响应用户的点击操作 a标签-可以响应用户的跳转等)

Obj.onfocus=function(){}  obj.onblur=function(){}  obj.focus();  obj.blur()

obj.select()------会把obj的内容全部选中  (选中的内容是可交互性的文本内容)

<input type="text" id="txt">
<button id="btn">选中文字</button>
window.onload=function(){
var txt = document.getElementById('txt');
var btn = document.getElementById('btn');
btn.onclick = function () {
txt.select();
}
}

二. event:事件对象,当一个对象发生的时候,和当前这个对象发生的这个事件有关的一些详细的信息都会被临时保存到一个指定的地方event对象,供我们在需要的时候调用。

如果一个函数是被事件函数调用的,那么,这个函数定义的第一个参数就是事件对象(event),它是一个内置的全局对象。

在使用的时候有浏览器兼容的问题     在标准的浏览器下 可以直接取到event 而在非标准的浏览下,是取不到的。    Var ev = ev || event;  ----解决了兼容性的问题。

document.onclick = function () {
fn();
}
function fn (ev){
var ev = ev || event;
alert(ev);
for (attr in ev) {
console.log(attr + '=' + ev[attr]);
}
}

三. clientX clientY ---当一个事件发生的时候,鼠标到页面可视区的距离

一个小小的列子  div跟随鼠标移动
<!DOCTYPE html>
<html ng-app = 'myApp'>
<head>
<title></title>
<meta name="name" content="content" charset="utf-8">
<style type="text/css" media="screen">
div{width:100px;height: 100px;background-color: red;position: absolute;}
</style>
<script type="text/javascript">
window.onload = function () {
var oDiv = document.getElementById('div1');
document.onmousemove = function (ev) {
var ev = ev || event;
var scrollTop = document.documentElement.scrollTop || document.body.scrollTop; oDiv.style.left = ev.clientX + 'px';
oDiv.style.top = ev.clientY + scrollTop + 'px'; }
}
</script>
</head>
<body>
<div id="div1"></div>
</body>
</html>

四.事件流

事件冒泡:当一个元素接收到事件的时候,会把他接受到的所有传播给他的父级,一直到顶层window.

<style type="text/css" media="screen">
div{padding: 40px;}
#div1{background-color: red;}
#div2 {background-color: blue;}
#div3 {background-color: green;}
</style>
<script type="text/javascript">
window.onload = function () {
var oDiv1 = document.getElementById('div1');
var oDiv2 = document.getElementById('div2');
var oDiv3 = document.getElementById('div3'); function aa(){
alert(this.id);
}
oDiv1.onclick = aa;
oDiv2.onclick = aa;
oDiv3.onclick = aa;
}
</script>
<div id="div1">
<div id="div2">
<div id="div3"></div>
</div>
</div>

当点击div3的时候,会依次弹出div3 div2 div1,当点击div2的时候,会依次弹出div2 div1,这个就是冒泡机制,会依次向父级一直冒泡,直至window.

阻止冒泡:当前要阻止冒泡的事件函数中调用event.cancelBubble = true;或者 event.stopPropagation();

绑定事件:给一个对象的同一个事件绑定多个不同的函数

兼容性:ie:obj.attachEvent(事件名称,事件函数)

  1. 没有捕获
  2. 事件名称有on
  3. 事件函数执行的顺序:标准的ie下为---正序    非标准的ie下为---倒序
  4. This指向window

标准:obj.addEventListener(事件名称,事件函数,是否捕获)

  1. 有捕获
  2. 事件名称没有on
  3. 事件执行的顺序是正序
  4. This指向触发改事件的对象
     window.onload = function () {
    var oDiv1 = document.getElementById('div1');
    function aa(){
    alert(this);
    }
    function bb(){
    alert(1);
    }
    // 正常情况下,bb函数会覆盖aa函数,值弹出1.
    // oDiv1.onclick = aa;
    // oDiv1.onclick = bb;
    // 在ie下,函数都会执行,但是执行的顺序不一样
    // oDiv1.attachEvent('onclick',aa);
    // oDiv1.attachEvent('onclick',bb);
    // 在标准浏览器下,函数都会正序执行
    oDiv1.addEventListener('click',aa,false);
    oDiv1.addEventListener('click',bb,false);
    }

    解决this的指向不同,利用call()方法,改变this的指向

  5. Call()方法,改变this的指向 call方法的第一个参数可以改变函数执行过程中的内部this的指向,call方法第二个参数开始就是原来函数的参数列表

    function fn1(a){
          alert(this);  }   function fn2(a,b){
          alert(this);
          alert(a+b);
     }
     //fn1();   //window
    // fn1.call(1); //1
     
    fn2.call(1,2,3)  //1  5
     
    fn2.call(null,2,3) //window 5
  6. 兼容ie以及标准浏览器的事件绑定函数
     function bind(obj,evname,fn) {
    if (obj.addEventListener) {
    obj.addEventListener(evname,fn,false);
    } else {
    obj.attachEvent('on'+evname, function () {
    fn.call(obj);
    })
    }
    }
  7. 关键一句:在W3C(或支持事件捕获的)浏览器中,先发生捕获的过程,再发生冒泡的过程。

      oDiv1.addEventListener('click',function(){
    alert(1);
    },true); //捕获事件
    oDiv1.addEventListener('click',function(){
    alert(2);
    },false); //冒泡事件
    oDiv3.addEventListener('click',function(){
    alert(3);
    },true); //捕获事件

    当点击div1的时候,会弹出1   2

    当点击div2的时候, 会弹出1    2

    当点击div3的时候   会弹出 1   3   2

    点击div1的时候,是捕获事件,会从最外层开始开始捕获事件,div1有2个事件,捕获时,弹出1,冒泡是弹出2.   所以会弹出1   2

    点击div2的时候,由于div2没有加事件,但是它默认的会执行捕获事件,从最外层开始,一直到div2  然后再向外层冒泡  所以会弹出  1   2

    点击div3的时候 是捕获事件,从最外层开始,一直到div3  ,然后再向外层冒泡  所以会弹出 1   3   2

  8. 取消事件绑定

    ie : obj.detachEvent(事件名称,事件函数)

    标准:obj.removeEventListener(事件名称,事件函数,是否捕获)

js的event事件的更多相关文章

  1. 【js】event(事件对象)详解

    1.事件对象 Event 对象代表事件的状态,比如事件在其中发生的元素.键盘按键的状态.鼠标的位置.鼠标按钮的状态. 什么时候会产生Event 对象呢? 例如: 当用户单击某个元素的时候,我们给这个元 ...

  2. js的event事件对象汇总

    JavaScript事件对象是浏览器默认传入的,但是对于浏览器的兼容问题,我们需要对事件对象进行兼容.但是jQuery已经帮我们解决了所有兼容性的问题,并且给我们添加了很多有用的方法.已经是比较历史的 ...

  3. js event 事件兼容浏览器 ie不需要 event参数 firefox 需要

    js event 事件兼容浏览器    ie不需要 event参数   firefox 需要 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 ...

  4. JavaScript -- 时光流逝(八):js中的事件Event的使用

    JavaScript -- 知识点回顾篇(八):js中的事件Event的使用 事件通常与函数配合使用,这样就可以通过发生的事件来驱动函数执行. (1) onabort : onabort 事件会在图像 ...

  5. 通过js触发onPageView和event事件获取页面信息

    注:图片如果损坏,点击文章链接:https://www.toutiao.com/i6814814715022148100/ 承接上一篇文档<js页面触发launch事件编写> pageVi ...

  6. JS学习笔记9之event事件及其他事件

    -->鼠标事件-->event事件对象-->默认事件-->键盘事件(keyCode)-->拖拽效果 一.鼠标事件 onclick ---------------鼠标点击事 ...

  7. JS(event事件)

    常用的event事件: 属性 此事件发生在何时... onabort 图像的加载被中断. onblur 元素失去焦点. onchange 域的内容被改变. onclick 当用户点击某个对象时调用的事 ...

  8. Event事件

    妙味课堂-Event事件 1.焦点:当一个元素有焦点的时候,那么他就可以接受用户的输入(不是所有元素都能接受焦点) 给元素设置焦点的方式: 1.点击 2.tab 3.js 2.(例子:输入框提示文字) ...

  9. 怎么理解js中的事件委托

    怎么理解js中的事件委托 时间 2015-01-15 00:59:59  SegmentFault 原文  http://segmentfault.com/blog/sunchengli/119000 ...

随机推荐

  1. maven私服搭建nexus/windows/linux(一)

    为什么要搭建nexus私服,原因很简单,有些公司都不提供外网给项目组人员,因此就不能使用maven访问远程的仓库地址,还有就是公司内部开发的一些版本的jar包,如果没有私服需要一人拷贝一份然后再自己安 ...

  2. 100_remove-duplicates-from-sorted-array

    /*@Copyright:LintCode@Author:   Monster__li@Problem:  http://www.lintcode.com/problem/remove-duplica ...

  3. java复习(4)---数字处理类

    java本身自带一些封装好的类方便数字问题的处理,review下方便以后使用 DecimalFormat类 可格式化数字格式,控制输出格式 Math类 提供三角函数.指数函数.取整函数.最大最小函数. ...

  4. tomcat的环境搭建

    tomcat搭建过程还是比较简单的,只需要安装好jdk,然后配置好环境变量,最后把tomcat安装上开启就可以了. 首先下载jdk,然后把下载下来的jdk放到/usr/local下,然后用rpm -i ...

  5. pdf.js实现在HTML下直接浏览pdf文档,无需插件即可实现

    近期,有一个朋友做B端,服务器存了大量的金融类数据,很多都是pdf文档,他现在的做法是,先将pdf文档转换成flash,再放到浏览器上给用户浏览,但是他告诉我,这种体验太差了,而且很好资源,空间已经快 ...

  6. 欲练JS,必先攻CSS——前端修行之路(码易直播)

    以下是直播大概内容的文字版: 感谢大家今天来到直播间收听本期的码易直播.今天我讲的主题是css,具体聊一下我大概的css学习历史,分享一些干货,希望这次分享对大家有所启发和帮助. 个人的css历史: ...

  7. 在iOS应用程序中使用Frida绕过越狱检测

           阿里聚安全在之前的三篇博客中介绍了利用Frida攻击Android应用程序,整个过程仿佛让开发者开启上帝视角,在本篇博客中,我们将会介绍在iOS应用程序中使用Frida绕过越狱检测.即使 ...

  8. Python的RSA加密和PBE加密

    最近在写接口的时候,遇到了需要使用RSA加密和PBE加密的情况,对方公司提供的DEMO都是JAVA的,我需要用python来实现. 在网上搜了一下,python的RSA加密这块写的还是比较多的,但是P ...

  9. 开源框架是如何通过JMX来做监控的(一) - JMX简介和Standard MBean

    相关文章目录: 开源框架是如何通过JMX来做监控的(一) - JMX简介和Standard MBean 开源框架是如何通过JMX来做监控的(二) - Druid连接池的监控 相信很多做Java开发的同 ...

  10. 增强for循环 -- foreach循环

    1  作用 简化迭代器的书写格式.(注意:foreach循环的底层还是使用了迭代器遍历.) 2  适用范围 如果是实现了Iterable接口的对象或者是数组对象都可以使用foreach循环. 3  格 ...