[关闭]
@YDS 2017-07-22T08:19:33.000000Z 字数 3299 阅读 260

js常用事件

js


常用事件

  1. document.getElementById("bnt1").onclick=function(){
  2. document.getElementById("p1").innerHTML="ddd";
  3. };
  1. var myname = document.getElementById("name");
  2. myname.onmouseover = function(e){
  3. this.style.color = "red";
  4. }
  1. document.getElementById('div2').onmousedown=function(){
  2. this.innerHTML="鼠标按下了";
  3. };
  4. document.getElementById('div2').onmouseup=function(){
  5. this.innerHTML="鼠标松开了";
  6. }

this简单使用

在匿名函数内,this代表绑定事件的元素(自己)

  1. document.getElementById("btn1").onclick=function(){
  2. this.style.backgroundColor = "red";
  3. }

查看事件对象

  1. document.getElementById("btn5").onclick=function(e){
  2. console.log(e); // 事件对象
  3. console.log(e.target);//发出事件的元素
  4. console.log(e.x); //事件的位置
  5. console.log(e.type);//事件的类型
  6. }

事件绑定和解除

addEventListener 和removeEventLister

addEventListener()与removeEventListener()用于处理指定和删除事件处理程序操作。所有的DOM节点中都包含这两种方法,并且它们都接受3个参数:要处理的时间名、作为事件处理程序的函数和一个布尔值。最后这个布尔值参数是true,表示在捕获阶段调用事件处理程序;如果是false,表示在冒泡阶段调用事件处理程序。(下一条即事件的冒泡和捕获)

addEventListener的参数一共有三个,语法为:
element.addEventListener(type,listener,useCapture)

详解

  1. var btn = document.getElementById("myBtn");
  2. btn.addEventListener("click", function () {
  3. alert(this.id);
  4. }, false);
  1. var btn = document.getElementById("myBtn");
  2. btn.addEventListener("click", function () {
  3. alert(this.id);
  4. }, false);
  5. btn.addEventListener("click", function () {
  6. alert("Hello World");
  7. }, false);

注意:addEventListener() 方法添加的事件处理函数不会覆盖已存在的事件处理函数。你可以向一个元素添加多个事件处理函数。比如对一个元素添加两个 "click" 事件。

  1. var btn = document.getElementById("myBtn");
  2. btn.addEventListener("click", function () {
  3. alert(this.id);
  4. }, false);
  5. btn.removeEventListener("click", function () { //无效!
  6. alert(this.id);
  7. }, false);

在这个例子中,我使用addEventListener()添加一个事件处理程序。虽然调用removeEventListener()是看似使用了相同的参数,但实际上,第二个参数与传入addEventListener()中的那一个完全不同的函数。而传入removeEventListener()中的事件处理程序函数必须与传入addEventListener()中的相同,如下面的例子所示:

  1. var btn = document.getElementById("myBtn");
  2. var handler = function () {
  3. alert(this.id);
  4. };
  5. btn.addEventListener("click", handler, false);
  6. btn.removeEventListener("click", handler, false); //有效!重写后的这个例子没有问题,是因为在addEventListener()和removeEventListener()中用相同的函数。

事件冒泡和捕获

事件传递有两种方式:冒泡与捕获。
在冒泡中,内部元素的事件会先被触发,然后再触发外部元素
在捕获中,外部元素的事件会先被触发,然后才会触发内部元素的事件
addEventListener(event, function, useCapture); useCapture默认值为 false, 是冒泡传递。当useCapture值为 true 时, 事件使用捕获传递。
事件冒泡:

  1. document.getElementById('div7').addEventListener('click', function(){
  2. alert('div7 click');
  3. }, false);
  4. document.getElementById('btn7').addEventListener('click', function(){
  5. alert('btn7 click');
  6. }, false);

事件捕获:

  1. document.getElementById('div7').addEventListener('click', function(){
  2. alert('div7 click');
  3. }, true);
  4. document.getElementById('btn7').addEventListener('click', function(){
  5. alert('btn7 click');
  6. }, true);
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注