Javascript动态绑定
<div onclick="test()"></div>
<script>
function test(){
//code
}
</script>
上面这种方法是很low逼的,用了这种方法工资就涨不上去你信不信?下面这种也是...
<div id="test"></div>
<script>
var test = document.getElementById("test");
test.onclick = function(){
//code
};
</script>
能不能用一个稍微有点逼格的方法?
<div id="test"></div>
<script>
var test = document.getElementById("test");
test.addEventListener("click",function(){
//code
});
</script>
addEventListener() 还能解绑
<div id="test"></div>
<script>
var test = document.getElementById("test");
function testFunction(){
//code
}
test.addEventListener("click",testFunction);
test.removeEventListener("click",testFunction);
</script>
听说这个方法对IE8无法向下兼容?没关系,我们还有attachEvent/detachEvent
<div id="test"></div>
<script>
var test = document.getElementById("test");
function testFunction(){
//code
} //绑定
if (test.addEventListener) {
test.addEventListener("click", testFunction);
} else if (test.attachEvent) {
test.attachEvent("onclick", testFunction);
} //解除
if (test.removeEventListener) {
test.removeEventListener("click", testFunction);
} else if (test.detachEvent) {
test.detachEvent("onclick", testFunction);
}
</script>
有一种库叫做jQuery...你可以用bind(),这么写...
<div id="test"></div>
<script>
$("#test").bind("click",function(){
//code
});
$("#test").unbind("click");
</script>
这么写...
<div id="test"></div>
<script>
$("#test").bind("click mousemove",function(){
//code
});
</script>
这么写...
<div id="test"></div>
<script>
$("#test").bind({
"click":function(){
//code
},
"mousemove":function(){
//code
}
});
</script>
还可以用live(),向当前或未来的匹配元素添加一个或多个事件处理器。可以这样写...
<div id="test"></div>
<script>
$("#test").live("click",function(){
//code
});
$("#test").die("click");
</script>
还可以这样写...
<div id="test"></div>
<script>
$("#test").live("click mousemove",function(){
//code
});
</script>
换着姿势写...
<div id="test"></div>
<script>
$("#test").live({
"click":function(){
//code
},
"mousemove":function(){
//code
}
});
</script>
还可以用delegate() 为指定的元素(被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数,适用于当前或未来的元素(比如由脚本创建的新元素)。
<div class="test">
<div id="test_inside"></div>
</div>
<script>
$(".test").delegate("#test_inside","click",function(){
//code
});
</script> <script>
$(".test").delegate("#test_inside","click mousemove",function(){
//code
});
</script> <script>
$(".test").delegate("#test_inside",{
"click":function(){
//code
},
"mousemove":function(){
//code
}
});
</script>
可是人家官网说了...
自从jquery1.7版本以后bind()函数推荐用on()来代替
live()只被jquery1.9版本以下支持,jquery1.9及其以上版本删除了这个方法,jquery1.9以上版本用on()方法来代替。
delegate()倒是一直保留着,可适用于jquery1.4.2及其以上版本,但是名字太丑了。
于是就这样...
<div class="test">
<div id="test_inside"></div>
</div>
<script>
$(".test").on("click", "#test_inside", function () {
//code
});
$(".test").off("click");
</script>
就这样...
<div class="test">
<div id="test_inside"></div>
</div>
<script>
$(".test").on("click mousemove","#test_inside",function(){
//code
});
</script>
就这样...
<div class="test">
<div id="test_inside"></div>
</div>
<script>
$(".test").on({
"click":function(){
//code
},
"mousemove":function(){
//code
}
},"#test_inside");
</script>
就这样被你征服...
注意:on()和delegate()两个参数的位置正好相反...城里人真会玩!Orz~~
补充说明:
bind()函数只能针对已经存在的元素进行事件的设置;但是live(),on(),delegate()均支持未来新添加元素的事件设置
<div class="test"></div>
<script>
//利用bind()方法,给P标签设置click方法 ======失败 没有任何反应=======
$(".test p").bind("click", function () {
alert("bind()添加单击事件成功!");
}); //利用live()方法.给P标签设置click方法 =======成功调用方法============
$(".test p").live("click", function () {
alert("live()添加单击事件成功!");
}); //利用delegate()方法.给P标签设置click方法 =======成功调用方法============
$(".test").delegate("p", "click", function () {
alert("delegate()添加单击事件成功!");
}); //利用on()方法.给P标签设置click方法 =======成功调用方法============
$(".test").on("click", "p", function () {
alert("on()添加单击事件成功!");
});
$(".test").append("<p>test</p>");
</script>
写在结尾
关于版本问题,这个事情不得不说。
bind()支持Jquery所有版本;live()支持jquery1.8-;delegate()支持jquery1.4.2+;on()支持jquery1.7+。
这是个让人纠结的问题,当一个天秤座的强迫症患者面对不同版本的jQuery和不同版本时代的方法的时候,选择成为了一个大问题。
但是如果你去看一看现在主流的js框架的源码你会发现,
怎么这么多on()啊啊啊啊啊啊啊啊
所以,用on()就对了!
其他的方法,封装了半天,最后底层代码还是调用onclick()什么的!
诚然,我也很讨厌废话,
写了那么长,有2/3都是在放屁!
可是总结就是这样,
做笔记就是这样,
来龙去脉要搞清楚,
因为我是一个天秤座的强迫症患者!
Javascript动态绑定的更多相关文章
- javascript绑定时间 含(IE)
script language = "javascript" type = "text/javascript"> function test(){ win ...
- 常见的原生javascript DOM操作
1.创建元素 创建元素:document.createElement() 使用document.createElement()可以创建新元素.这个方法只接受一个参数,即要创建元素的标签名.这个标签名在 ...
- js dom 操作技巧
1.创建元素 创建元素:document.createElement() 使用document.createElement()可以创建新元素.这个方法只接受一个参数,即要创建元素的标签名.这个标签名在 ...
- (转)Jquery+Ajax实现Select动态定数据
解决思路: 在数据库中建立类型字典式表.将下拉框需要添加的项,在数据库表里中文.英文名称对应起来. 下拉框动态绑定数据库表中需要字段. <div id="bgDiv" sty ...
- Web_javaScript
JavaScript 的使用 第1章 JavaScript起源 1.1 起源 N年前 拨号上网,网速很慢,数据提交到服务器端验证,体验很差 于是,就有人在想:能不能让这些数据在浏览器端验证呢? 20世 ...
- javascript下动态this与动态绑定实例代码
this 的值取决于 function 被调用的方式,一共有四种, 如果一个 function 是一个对象的属性,该 funtion 被调用的时候,this 的值是这个对象. 如果 function ...
- javascript中的this与函数讲解
前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...
- Javascript 严格模式详解
转自http://www.ruanyifeng.com/blog/2013/01/javascript_strict_mode.html 一.概述 除了正常运行模式,ECMAscript 5添加了第二 ...
- JavaScript学习笔记(一)——延迟对象、跨域、模板引擎、弹出层、AJAX示例
一.AJAX示例 AJAX全称为“Asynchronous JavaScript And XML”(异步JavaScript和XML) 是指一种创建交互式网页应用的开发技术.改善用户体验,实现无刷新效 ...
随机推荐
- 进阶系列(8)——匿名方法与lambda表达式
一 匿名方法的介绍 匿名方法是为了简化委托的实现,方便调用委托方法而出现的,同时,匿名方法也是学好lambda表达式的基础.在委托调用的方法中,如果方法只被调用一次,这个时候我们就没有必要创建 ...
- 让程序运行更加面向用户——电梯V2.1
电梯V2.1 GitHub仓库地址 Problem 为程序添加命令行参数(自行利用搜索引擎进行学习). 写成 .cpp .h 文件分离的形式(大多数同学已经达到). 继续完善函数分离.模块化思想. 要 ...
- 软工1816 · Alpha冲刺(5/10)
团队信息 队名:爸爸饿了 组长博客:here 作业博客:here 组员情况 组员1(组长):王彬 过去两天完成了哪些任务 后端代码复审 福大各个食堂的菜品口味量化.属性标记 组织前后端线下协作 接下来 ...
- 新手使用github过程记录
初次接触github,记录下我的使用过程.一开始确实有些懵,但好在网上这类的教程有很多,过程也很详细易懂,按照网上的教程走完全没问题,感谢无私分享辛苦整理的各位前辈们. 注册github账号 创建一个 ...
- 领悟JavaScript面向对象
JavaScript 是面向对象的.但是不少人对这一点理解得并不全面. 在 JavaScript 中,对象分为两种.一种可以称为“普通对象”,就是我们所普遍理解的那些:数字.日期.用户自定义的对象(如 ...
- WebService(一)
1.简介 Web service是一个平台独立的,低耦合的,自包含的.基于可编程的web的应用程序,可使用开放的XML(标准通用标记语言下的一个子集)标准来描述.发布.发现.协调和配置这些应用程序,用 ...
- 设计模式PHP篇(二)————工厂模式
一个很简单的工厂模式.代码如下: <?php interface Person { public function sex(); } class Man implements Person { ...
- 【转】Apache httpd.conf配置解释
转自:http://jafy00.blog.51cto.com/2594646/501373 常用配置指令说明 1. ServerRoot:服务器的基础目录,一般来说它将包含conf/和logs/子目 ...
- 【明哥报错簿】之【HTTP Status 500 - Servlet.init() for servlet mvc-dispatcher threw exception】
报错:java.lang.NoClassDefFoundError: /factory/config/EmbeddedValueResolver spring或者jdk的问题,解决办法:spring3 ...
- C++解析(18):C++标准库与字符串类
0.目录 1.C++标准库 2.字符串类 3.数组操作符的重载 4.小结 1.C++标准库 有趣的重载--操作符 << 的原生意义是按位左移,例:1 << 2;,其意义是将整数 ...