JavaScript中绑定事件的三种方式及去除绑定


Posted in Javascript onNovember 05, 2016

在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能有所帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
javascript学习笔记(七)利用javascript来创建和存储cookie
Apr 08 Javascript
Javascript/Jquery——简单定时器的多种实现方法
Jul 03 Javascript
JavaScript生成福利彩票双色球号码
May 15 Javascript
JavaScript驾驭网页-DOM
Mar 24 Javascript
vue.js入门教程之计算属性
Sep 01 Javascript
jQuery操作复选框(CheckBox)的取值赋值实现代码
Jan 10 Javascript
微信小程序页面开发注意事项整理
May 18 Javascript
angularjs下拉框空白的解决办法
Jun 20 Javascript
微信小程序视图template模板引用的实例详解
Sep 20 Javascript
Vue+elementui 实现复杂表头和动态增加列的二维表格功能
Sep 23 Javascript
JS实现吸顶特效
Jan 08 Javascript
jQuery实现简单三级联动效果
Sep 05 jQuery
Ajax与服务器(JSON)通信实例代码
Nov 05 #Javascript
Javascript 普通函数和构造函数的区别
Nov 05 #Javascript
Javascript 函数的四种调用模式
Nov 05 #Javascript
详解利用exif.js解决ios手机上传竖拍照片旋转90度问题
Nov 04 #Javascript
jQuery中 $ 符号的冲突问题及解决方案
Nov 04 #Javascript
JAVA Web实时消息后台服务器推送技术---GoEasy
Nov 04 #Javascript
详解js运算符单竖杠“|”与“||”的用法和作用介绍
Nov 04 #Javascript
You might like
PHP函数篇之掌握ord()与chr()函数应用
2011/12/05 PHP
解析PHP中empty is_null和isset的测试
2013/06/29 PHP
PHP扩展模块Pecl、Pear以及Perl的区别
2014/04/09 PHP
PHP 正则表达式小结
2015/02/12 PHP
php通过rmdir删除目录的简单用法
2015/03/18 PHP
php使用指定编码导出mysql数据到csv文件的方法
2015/03/31 PHP
PHP实现在线阅读PDF文件的方法
2015/06/17 PHP
详解WordPress开发中的get_post与get_posts函数使用
2016/01/04 PHP
老生常谈PHP面向对象之注册表模式
2017/05/26 PHP
许愿墙中用到的函数
2006/10/07 Javascript
某人初学javascript的时候写的学习笔记
2010/12/30 Javascript
JS两种定义方式的区别、内部原理
2013/11/21 Javascript
JQuery中两个ul标签的li互相移动实现方法
2015/05/18 Javascript
详细解读JavaScript的跨浏览器事件处理
2015/08/12 Javascript
js中利用tagname和id获取元素的方法
2016/01/03 Javascript
JavaScript日期对象(Date)基本用法示例
2017/01/18 Javascript
Js利用Canvas实现图片压缩功能
2017/09/13 Javascript
详解express + mock让前后台并行开发
2018/06/06 Javascript
[34:27]DOTA2上海特级锦标赛B组败者赛 VG VS Spirit第一局
2016/02/26 DOTA
自动化Nginx服务器的反向代理的配置方法
2015/06/28 Python
全面理解Python中self的用法
2016/06/04 Python
网站渗透常用Python小脚本查询同ip网站
2017/05/08 Python
Python2.7环境Flask框架安装简明教程【已测试】
2018/07/13 Python
pygame实现简易飞机大战
2018/09/11 Python
python pyheatmap包绘制热力图
2018/11/09 Python
python3+openCV 获取图片中文本区域的最小外接矩形实例
2020/06/02 Python
Oracle里面常用的数据字典有哪些
2014/02/14 面试题
函授毕业生自我鉴定范文
2014/03/25 职场文书
毕业班联欢会主持词
2014/03/27 职场文书
捐款倡议书怎么写
2014/05/13 职场文书
党小组鉴定意见
2015/06/02 职场文书
《小摄影师》教学反思
2016/02/18 职场文书
煤矿施工安全协议书
2016/03/22 职场文书
python实现简易名片管理系统
2021/04/11 Python
聊一聊python常用的编程模块
2021/05/14 Python
Python通过loop.run_in_executor执行同步代码 同步变为异步
2022/04/11 Python