@YDS
2017-07-22T08:19:33.000000Z
字数 3299
阅读 260
js
document.getElementById("bnt1").onclick=function(){document.getElementById("p1").innerHTML="ddd";};
onchange:对象发生变化时
onchange属性可以使用于:<input>,<select>和<textare>document.getElementById("input1").onchange=function(){this.value=this.value.toUpperCase();}toUpperCase() 方法用于把字符串转换为大写。
var myname = document.getElementById("name");myname.onmouseover = function(e){this.style.color = "red";}
document.getElementById('div2').onmousedown=function(){this.innerHTML="鼠标按下了";};document.getElementById('div2').onmouseup=function(){this.innerHTML="鼠标松开了";}
在匿名函数内,this代表绑定事件的元素(自己)
document.getElementById("btn1").onclick=function(){this.style.backgroundColor = "red";}
document.getElementById("btn5").onclick=function(e){console.log(e); // 事件对象console.log(e.target);//发出事件的元素console.log(e.x); //事件的位置console.log(e.type);//事件的类型}
addEventListener 和removeEventLister
addEventListener()与removeEventListener()用于处理指定和删除事件处理程序操作。所有的DOM节点中都包含这两种方法,并且它们都接受3个参数:要处理的时间名、作为事件处理程序的函数和一个布尔值。最后这个布尔值参数是true,表示在捕获阶段调用事件处理程序;如果是false,表示在冒泡阶段调用事件处理程序。(下一条即事件的冒泡和捕获)
addEventListener的参数一共有三个,语法为:
element.addEventListener(type,listener,useCapture)
var btn = document.getElementById("myBtn");btn.addEventListener("click", function () {alert(this.id);}, false);
var btn = document.getElementById("myBtn");btn.addEventListener("click", function () {alert(this.id);}, false);btn.addEventListener("click", function () {alert("Hello World");}, false);
注意:addEventListener() 方法添加的事件处理函数不会覆盖已存在的事件处理函数。你可以向一个元素添加多个事件处理函数。比如对一个元素添加两个 "click" 事件。
var btn = document.getElementById("myBtn");btn.addEventListener("click", function () {alert(this.id);}, false);btn.removeEventListener("click", function () { //无效!alert(this.id);}, false);
在这个例子中,我使用addEventListener()添加一个事件处理程序。虽然调用removeEventListener()是看似使用了相同的参数,但实际上,第二个参数与传入addEventListener()中的那一个完全不同的函数。而传入removeEventListener()中的事件处理程序函数必须与传入addEventListener()中的相同,如下面的例子所示:
var btn = document.getElementById("myBtn");var handler = function () {alert(this.id);};btn.addEventListener("click", handler, false);btn.removeEventListener("click", handler, false); //有效!重写后的这个例子没有问题,是因为在addEventListener()和removeEventListener()中用相同的函数。
事件传递有两种方式:冒泡与捕获。
在冒泡中,内部元素的事件会先被触发,然后再触发外部元素
在捕获中,外部元素的事件会先被触发,然后才会触发内部元素的事件
addEventListener(event, function, useCapture); useCapture默认值为 false, 是冒泡传递。当useCapture值为 true 时, 事件使用捕获传递。
事件冒泡:
document.getElementById('div7').addEventListener('click', function(){alert('div7 click');}, false);document.getElementById('btn7').addEventListener('click', function(){alert('btn7 click');}, false);
事件捕获:
document.getElementById('div7').addEventListener('click', function(){alert('div7 click');}, true);document.getElementById('btn7').addEventListener('click', function(){alert('btn7 click');}, true);