添加事件 
IE: attachEvent 
Other: addEventListener

  1. var button = document.getElementById("buttonId");
  2. if(button.addEventListener){
  3. button.addEventListener("click",eventFunction,false);
  4. }else if(button.attachEvent){
  5. button.attachEvent("onclick",eventFunction);
  6. }

删除事件 
IE: detachEvent 
Other: removeEventListener

事件冒泡机制 
IE: 事件从它发生的地方被触发,然后向DOM结构的上层冒泡 
Other: 事件先向下沉入到目标元素,再向上冒泡 
     addEventListener( , ,[true|false])

  • true: 向下沉入时截获事件
  • false: 向上冒泡时截获事件

停止事件冒泡: 
IE: window.event.cancelBubble=false; 
Other: e.stopPropagation();

实验的例子:

  1. function bindEvent() {
  2. var button = document.getElementById("buttonId");
  3. if (button.addEventListener) {
  4. alert("Other browser");
  5. //button.addEventListener("click",showEvent,false);
  6. //button.addEventListener("click",showEvent2,false);
  7. button.addEventListener("click", showEvent, true);
  8. button.addEventListener("click", showEvent2, true);
  9. } else if (button.attachEvent) {
  10. alert("IE browser");
  11. button.attachEvent("onclick", showEvent);
  12. button.attachEvent("onclick", showEvent2);
  13. }
  14. }
  15. function removeEvent() {
  16. var button = document.getElementById("buttonId");
  17. if (button.removeEventListener) {
  18. alert("Other browser");
  19. //button.removeEventListener("click",showEvent,false);
  20. button.removeEventListener("click", showEvent, true);
  21. } else if (button.detachEvent) {
  22. alert("IE browser");
  23. button.detachEvent("onclick", showEvent);
  24. }
  25. }
  26. function showEvent(e) {
  27. if (window.event != undefined) {
  28. window.event.cancelBubble = true;
  29. } else if (e.stopPropagation) {
  30. e.stopPropagation();
  31. }
  32. alert("Event here!");
  33. }
  34. function showEvent2() {
  35. alert("Other event here!");
  36. }
  37. function divEvent() {
  38. alert("Div Event");
  39. }
  1. <div onclick="divEvent()">
  2. <input type="button" id="buttonId" value="showEvent"/>
  3. </div>

键盘事件

  1. window.onload=function(){
  2. //绑定键盘事件
  3. document.onkeydown=showkey;
  4. }
  5. function showkey(e){
  6. var key;
  7. if(window.event)
  8. key= window.event.keyCode;
  9. else
  10. key= e.keyCode;
  11. alert(String.fromCharCode(key));
  12. }

鼠标事件 
获取mouse的位置 
IE: clientX,clientY 
Other: pageX, pageY

    1. document.onmouseover= showPosition;

JS基础学习四:绑定事件的更多相关文章

  1. Node.js基础学习四之注册功能

    前言:在Node.js学习(二)和(三)中介绍了如何在Node.js 中获取登录的用户名和密码与数据库进行验证并返回数据给客户端 需求:实现注册功能 为了区分登录和注册是两个不同的请求,在端口后面加上 ...

  2. JS基础学习——闭包

    JS基础学习--闭包 什么是闭包 闭包的定义如下,它的意思是闭包使得函数可以记住和访问它的词法范围,即使函数是在它声明的词法范围外执行.更简单来讲,函数为了自己能够正确执行,它对自己的词法范围产生闭包 ...

  3. JS基础学习——作用域

    JS基础学习--作用域 什么是作用域 变量的作用域就是变量能被访问到的代码范围,比如在下面的这个js代码中,变量a的作用域就是函数foo,因此在全局作用域内的console.log(a)语句不能访问到 ...

  4. JS基础学习——对象

    JS基础学习--对象 什么是对象 对象object是JS的一种基本数据类型,除此之外还包括的基本数据类型有string.number.boolean.null.undefined.与其他数据类型不同的 ...

  5. Js为Dom元素绑定事件须知

    为异步加载的Dom 元素绑定事件必须在加载完成之后绑定: $('body').load('LearnClickBinding.ashx');$('a').click(function () { ale ...

  6. Python基础学习四

    Python基础学习四 1.内置函数 help()函数:用于查看内置函数的用途. help(abs) isinstance()函数:用于判断变量类型. isinstance(x,(int,float) ...

  7. salesforce lightning零基础学习(四) 事件(component events)简单介绍

    lightning component基于事件驱动模型来处理用户界面的交互.这种事件驱动模型和js的事件驱动模型也很相似,可以简单的理解成四部分: 1.事件源:产生事件的地方,可以是页面中的输入框,按 ...

  8. vue学习(四) v-on:事件绑定

    //html <div id="app"> <input type="button" value="ok" v-bind: ...

  9. JS 基础学习随想

    2012年就已经接触过了js,给我的印象:这是一门谈不上复杂的语言.大概这就是所谓的学的越浅,用的越少,觉得自己会的东西好像得更多吧!开始做基础练习题的时候觉得好像都十分简单.可是后来在做到对象数组的 ...

随机推荐

  1. 开发环境入门 linux基础 基本操作命令(部分) 文本结构和基本命令

    文本结构和基本命令 linux系统中系统提示符:$ 表示普通用户 su  root切换用户命令(用户名 root),输入密码,切换到其他用户状态 root 命令提示符:# exit 退出当前用户,返回 ...

  2. Mysql数据库服务器配置文件/etc/my.cnf的详细配置

    以下是 Mysql数 据库服务器配置文件 /etc/my.cnf的详细配置.应用场合是 InnoDB引擎, 4核 CPU, 32位SUSE.   [client] port        = 3306 ...

  3. C#实现有向无环图(DAG)拓扑排序

    对一个有向无环图(Directed Acyclic Graph简称DAG)G进行拓扑排序,是将G中所有顶点排成一个线性序列,使得图中任意一对顶点u和v,若边(u,v)∈E(G),则u在线性序列中出现在 ...

  4. leetcode424

    public class Solution { public int CharacterReplacement(string s, int k) { int len = s.Length; ]; , ...

  5. CentOS 6.3 下编译Nginx(笔记整理)

    1. 安装关联程序 [root@localhost opt]# yum search gcc [root@localhost opt]# yum install gcc-c++ [root@local ...

  6. IE6中浮动双边距bug

    想要创建出漂亮的网页设计, 除了要认真学习每一个html和CSS代码之外,不可能不去了解一下臭名昭著的IE6和更早的那些IE浏览器的坏脾气,因为你本来写出的规规矩矩的代码, 漂亮的设计就此就要完成了, ...

  7. PHP的count(数组)和strlen(字符串)的内部实现

    PHP的count(数组)和strlen(字符串)的内部实现上是直接显示一个长度变量,还是重头依次数一遍有多少个元素?关乎我理解这2个函数的效率..希望高人能从php的c源码上讲一讲.没有源码看过源码 ...

  8. webfrom 母版页

    ASP.NET中母版页作用 一是提高代码的复用(把相同的代码抽出来) 二是使整个网站保持一致的风格和样式. 母版页存在就一定要有内容页的存在,否则母版页的存在就没有了意义. .master 一.添加母 ...

  9. git在eclipse中的配置 完整版 转载

    http://www.cnblogs.com/zhxiaomiao/archive/2013/05/16/3081148.html

  10. mongodb3.0版本的2种引擎对比

    mongodb3.0以后 增加了wiredtiger引擎.常规引擎也升级到MMAPv1引擎(MongoDB2.6及以下版本用的是MMAP引擎):   mmapv1引擎:             col ...