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高级程序设计》学习笔记)
Jul 04 Javascript
JS动态修改表格cellPadding和cellSpacing的方法
Mar 31 Javascript
JavaScript页面实时显示当前时间实例代码
Oct 23 Javascript
读Javascript高性能编程重点笔记
Dec 21 Javascript
Es6 Generator函数详细解析
Feb 24 Javascript
Vue.js实现的表格增加删除demo示例
May 22 Javascript
php中and 和 &amp;&amp;出坑指南
Jul 13 Javascript
JavaScript创建防篡改对象的方法分析
Dec 30 Javascript
JavaScript实现背景自动切换小案例
Sep 27 Javascript
javascript解析json格式的数据方法详解
Aug 07 Javascript
JavaScript实现网页留言板功能
Nov 23 Javascript
vue代码分块和懒加载非必要资源文件
Apr 11 Vue.js
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开发者的10个技巧
2011/02/25 PHP
php函数连续调用实例分析
2015/07/30 PHP
初识ThinkPHP控制器
2016/04/07 PHP
PHP实现文件上传下载实例
2016/10/18 PHP
php json相关函数用法示例
2017/03/28 PHP
php微信公众号开发之答题连闯三关
2018/10/20 PHP
用Jquery实现可编辑表格并用AJAX提交到服务器修改数据
2009/12/27 Javascript
通过javascript的匿名函数来分析几段简单有趣的代码
2010/06/29 Javascript
关于document.cookie的使用javascript
2010/10/29 Javascript
使用javascript控制cookie显示和隐藏背景图
2014/02/12 Javascript
全面解析Bootstrap排版使用方法(标题)
2015/11/30 Javascript
jQuery常见的遍历DOM操作详解
2018/09/05 jQuery
详解vue中localStorage的使用方法
2018/11/22 Javascript
浅谈Vue.js 中的 v-on 事件指令的使用
2018/11/25 Javascript
vue的路由映射问题及解决方案
2019/10/14 Javascript
Vue中点击active并第一个默认选中功能的实现
2020/02/24 Javascript
VUE中setTimeout和setInterval自动销毁案例
2020/09/07 Javascript
Python import自定义模块方法
2015/02/12 Python
详细分析python3的reduce函数
2017/12/05 Python
使用 Python 实现微信群友统计器的思路详解
2018/09/26 Python
libreoffice python 操作word及excel文档的方法
2019/07/04 Python
python实现简单井字棋游戏
2020/03/04 Python
Python内存映射文件读写方式
2020/04/24 Python
VSCode配合pipenv搞定虚拟环境的实现方法
2020/05/17 Python
基于python实现简单C/S模式代码实例
2020/09/14 Python
简单总结CSS3中视窗单位Viewport的常见用法
2016/02/04 HTML / CSS
CSS3 实现的加载动画
2020/12/07 HTML / CSS
英国旅游额外服务市场领导者:Holiday Extras(机场停车场、酒店、接送等)
2017/10/07 全球购物
英国快时尚女装购物网站:PrettyLittleThing
2018/08/15 全球购物
Pandora德国官网:购买潘多拉手链、戒指、项链和耳环
2020/02/20 全球购物
装饰活动策划方案
2014/02/11 职场文书
婚礼主持词开场白
2014/03/13 职场文书
工业设计毕业生自荐信
2014/04/13 职场文书
社区文化建设方案
2014/05/02 职场文书
装饰公司活动策划方案
2014/08/23 职场文书
工厂仓库管理员岗位职责
2015/04/09 职场文书