在JavaScript中,有三种常用的绑定事件的方法
第一种办法
函数写在结构层里面
非常不好,使页面很混乱,行为与结构得不到分离
<input type="button" onclick="func();">
绑定事件的第二种办法
好处:行为与结构开始分离
缺点:
第二种绑定方式中只能给一个时间绑定一个处理函数
即.onclick = fn1; . onclick = fn2 最终的效果是onclick = fn2
<select name="xueli" > <option value="">请选择学历</option> <option value="大学" >大学</option> <option value="中学">中学</option> <option value="初中">初中</option> <option value="小学">小学</option> </select> <form action=""> <p>Email:<input type="text" name="email"> 姓名:<input type="text" name="ming" > </p> </form>
document.getElementsByTagName('select')[0].onclick= function (){
alert('嘻嘻');
}
document.getElementsByName('email')[0].onblur=function (){
alert('哈哈哈');
}
window.onload = function(){
var d = document.getElementById('school');
function fn1(){
alert('hello');
}
function fn2(){
alert('world');
}
d.onclick = fn1;//赋值操作 最终显示fn2
d.onclick = fn2;
}
绑定事件的第三种办法
//错误写法1
window.onload = function(){
var d = document.getElementById('school');
function fn1(){//this此时指向window
this.style.background = 'blue';
}
function fn2(){//this此时指向window
this.style.background = 'red';
}
//写一个匿名函数
//最终的出现错误
d.onclick = function (){
fn1();
fn2();
//fn1 fn2是属性window的 实际上是这样 window.fn1() window.fn2()
}
}
下面这种写法没有问题 但是给DOM树额外增加了两个变量
window.onload = function(){
var d = document.getElementById('school');
d.fn1 = function (){//fn1是d的属性 最终this此时指向DOM对象
this.style.background = 'blue';
}
d.fn2 = function (){//this此时指向DOM对象
this.style.background = 'red';
}
//匿名函数 调用上面两个函数
d.onclick = function (){
this.fn1();
this.fn2();
}
}
不在使用onclick
window.onload = function(){
var d = document.getElementById('school');
//达到了一次绑定两个函数
d.addEventListener('click',function () {alert('blue');this.style.background ='blue'});
d.addEventListener('click',function () {alert('red');this.style.background ='red'});
}
去除绑定 不能用匿名函数 匿名函数 当时产生 当时消失
var fn1 = function () {alert('blue');this.style.background ='blue'};
var fn2 = function () {alert('red');this.style.background ='red'};
function adde(){
var d = document.getElementById('school');
d.addEventListener('click',fn1);
d.addEventListener('click',fn2);
}
function reme(){
var d = document.getElementById('school');
//d.removeEventListener('click',fn1);//只剩fn1
d.removeEventListener('click',fn2);
}
在IE下第三种绑定事件的方法
<div id="school"> </div> <input type="button" value="加事件" onclick="adde();"> <input type="button" value="减事件" onclick="reme();">
var fn1 = function () {alert('blue');this.style.background ='blue'};
var fn2 = function () {alert('red');this.style.background ='red'};
function adde(){
var d = document.getElementById('school');
// IE6,7是后绑定的事件先发生
d.attachEvent('onclick',fn1);
d.attachEvent('onclick',fn2); //fn2先发生
}
function reme(){
var d = document.getElementById('school');
//d.deltachEvent('click',fn1);//只剩fn1
d.deltachEvent('click',fn2);
}
总结
以上就是JavaScript中绑定事件与去除绑定的三种方式,希望本文的内容对大家学习或者使用Javascript能有所帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“JavaScript中绑定事件的三种方式及去除绑定”评论...
更新日志
2025年10月27日
2025年10月27日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]