`
风雪涟漪
  • 浏览: 506946 次
  • 性别: Icon_minigender_1
  • 来自: 大连->北京
博客专栏
952ab666-b589-3ca9-8be6-3772bb8d36d4
搜索引擎基础(Search...
浏览量:9009
Ae468720-c1b2-3218-bad0-65e2f3d5477e
SEO策略
浏览量:18385
社区版块
存档分类
最新评论

Javascript 在浏览器环境中 (六) 事件

阅读更多

事件

事件的例子很多了。如用户输入,点击按钮等等。可以把一个javascript函数赋给一个事件(这个可以叫做事件监听器或者事件处理器),当事件发生了,就会执行这个函数。

 

基于内置的HTML属性

添加一个时间最快的方法就是,直接添加到html属性中,代码如下

<div onclick="alert('aaa!')">click</div>

当用户点击这个div的时候,alert('aaa')就被执行了。发现了这种方式并没有明显的函数来监听这个事件,但是这个函数已经在后台创建了。

 

元素的属性

另一种方法是,把一个函数赋给元素的属性。代码如下

<div id="my-div">click</div>
<script type="text/javascript">
  var myelement = document.getElementById('my-div');
  myelement.onclick = function() {
    alert('aaa!');
    alert('bbb!');
  }
</script>

这个方法很面显得要比第一种方式要好,因为它实现了html代码和javascript代码的分离了。 一定要知道html的作用在于内容,而javascript是行为,css是用于样式的。我们尽可能的让这三部分进行分离。

缺点是灵活度不够,只能一个函数监听一个事件。下面的方法就可以解决这个问题。

DOM事件监听器

最好的方式是使用时间监听器,这样就可以用许多函数监听一个事件。当发生事件的时候,所有监听的函数就会执行。所有的函数都是独立的,不需要管其他的函数。代码如下

var mypara = document.getElementById('my-div');
mypara.addEventListener('click', function() {alert('Boo!')}, false);
mypara.addEventListener('click', console.log, false);

这段javascript用addEventListener去监听click事件。第一个参数是事件的类型,第二个参数是一个函数,匿名函数也可以。当click发生click事件的时候,函数被执行,并且传入一个event对象。

 

事件的捕捉和冒泡

下面让我们详细的来说下 addEventListener() 第三个参数。

<body>
  <ul>
    <li><a href="http://phpied.com">my blog</a></li>
  </ul> 
</body>

 当你点击这个链接,当然也同样点击了li,ul,body.一个click链接,就相当于点击了这个document了。这就是事件的传播。事件的传播可以用两种方法实现

  • 时间的捕捉-这个点击事件首先发生在document上,然后是body,然后是ul,然后是li,最后是a。
  • 事件的冒泡-和上一个过程刚好相反。先从a开始在传播到document。

DOM 2规范建议事件的传播分为三个阶段。捕获,目标,冒泡。意思就是document->a 再从 a->document.这个过程。。。event对象有eventPhase属性,能返回当前的阶段。

 

说说残酷的现实把。大家都知道历史上是ie和netscape,它们都实现了规范的一部分。IE实现的是冒泡,而netscape实现的是捕获。现在firefox,opera都实现了三个阶段。但是ie还是冒泡。。。

 

我们看看关于事件传播的实际意义

  • 关于第三个参数就是是否使用事件的传播。一般为了跨浏览器,这个参数最好设为false以及用冒泡的实现方式。
  • 可以在监听器中,控制事件的传播。因此可以停止冒泡。我们可以使用事件对象的stopPropagation方法。
  • 我们也可以用事件代理。如果在div有10个按钮的话,你可以把每个按钮添加一个监听器。但是最好的方法是监听div。当事件发生后,判断哪个按钮被点击就可以了。

在IE中,用setCapture和releaseCapture方法,但是仅仅适用于鼠标事件。

 

停止事件的传播

<p id="closer">final</p>

 一个函数用来处理click事件。

function paraHandler(){alert('clicked paragraph');}

 接下来让这个函数作为一个事件的监听器

var para = document.getElementById('closer');
para.addEventListener('click', paraHandler, false);

 接下来,在分别为document,body,window添加监听器。

document.body.addEventListener('click', function(){alert ('clicked body')}, false);
document.addEventListener('click', function(){alert ('clicked doc')}, false);
window.addEventListener('click', function(){alert('clicked window')}, false);

 需要注意的是DOM规范并没有提到关于window的事件,DOM处理的是DOCUMENT和浏览器没啥关系。IE是不会有window的事件传播的,而firefox可以。

 

我们测试一下。执行的顺序如下

clicked paragraph
clicked body
clicked doc
clicked window

 

这个就可以看出来事件的传播。与addEventLister()相反的方法是removeEventListener().参数都是相同的。让我们移除这个监听器。

para.removeEventListener('click', paraHandler, false);

 如果这么做会发现,结果如下

clicked body
clicked doc
clicked window

 

让我们来看看如何停止事件的传播。你可以调用 stopPropagation() 方法。

function paraHandler(e){
  alert('clicked paragraph');
  e.stopPropagation();
}
para.addEventListener('click', paraHandler, false);

 当我们再次点击p的时候,发现只弹出一个alert。事件停止了传播。

 

需要注意的是,removeEventListener不能移除匿名函数的情况,这两个匿名函数是两个内存,下面的代码是不能移除监听器的。

document.body.removeEventListener('click',
    function(){
        alert('clicked body')
    }, 
false); //  不能移除监听器。

 

阻止默认的行为

有许多浏览器事件有默认的行为。如link就是个例子。你click link默认的行为是跳转到另一个页面。我们可以禁止这个链接的行为。我们可以调用 preventDefault()方法去实现。

 

下面个例子就是在click链接之后,有提示信息出现。来确认是否跳转。代码如下

//  获取所有链接的对象
var all_links = document.getElementsByTagName('a'); 
for (var i = 0; i < all_links.length; i++) { // 循环链接
  all_links[i].addEventListener(
    'click', // 事件的类型
    function(e){事件的函数
      if (!confirm('Are you sure you want to follow this link?')){
        e.preventDefault();
      }
    },
    false); //事件的捕获为false
}

 注意不是所有的事件都可以阻止。

 

跨浏览器的事件监听器

现在的大部分浏览器都支持DOM1规范。在DOM2规范之前,事件并没有规范化。所以出现了大量浏览器事件兼容 的问题。先看段代码

document.addEventListener('click', function(e){}, false);

让我们看看IE中有啥不一样的。

  • 在IE中并没有addEventListener方法。在IE5之后可以用attachEvent
  • 当使用attachEvent,click变为onclick.
  • 如果有标签属性的方式来监听事件,是不会有event对象传入到函数中的。(就是开篇所说的前两个实现事件的方式。。)但在IE中,无论是什么方式,IE都会传入一个window.event。
  • 在IE中,不会获取target属性,来知道哪个元素上的事件发生了。但是我们可以用srcElement来取代它。
  • 以前说过了,IE中没有事件的捕获,只有事件的冒泡。
  • 并没有stopPropagation()方法,可以设置cancelBubble属性为true。
  • 没有preventDefault() 方法,而是用returnValue为false来取代它。
  • 删除监听器可以用 detachEvent(). 来取代removeEventListener() 

下面写一个跨浏览器的例子

function callback(evt) {
  evt = evt || window.event;//如果evt不存在,说明是ie,赋给evt一个window.event.
  //判断target是否存在,不存在的话就是ie用evt.srcElment来取代标准的target.
  var target = (typeof evt.target !== 'undefined') ? evt.target : evt.srcElement;
  // 下面可以写业务逻辑了。

}
// 开始监听一个click事件。
if (document.addEventListener){ // 如果存在就是FF
  document.addEventListener('click', callback, false); 
} else if (document.attachEvent){ // 不存在就是IE
  document.attachEvent('onclick', callback);
} else {//其他的浏览器
  document.onclick = callback;
}

 

事件的类型

上面说的例子都是针对click事件的,下面来说下事件的类型。这些事件都是各个浏览器通用的事件,每个浏览器的事件各不相同。如果需要其他特殊的事件就要去查看文档了。

  • 鼠标事件:mouseup,mousedown,click(就是mousedown,mouseup的连贯),dbclick
  • 键盘事件:keydown,keypress,keyup.
  • load,一个图片或者页面以及它所有的元素加载完毕执行的事件,Unload-用户离开页面。beforeunload-一般用来提示用户离开页面。
  • abort:在firefox中用户停止页面的读取,在IE中是停止图片的读取。
  • error:IE和Firefox中javascript报错,或者在IE中,图片不能读取。
  • resize:浏览器大小更改。scoll,页面scoll的时候,contextmenu(右键的菜单)
  • focus-进入一个表单
  • blur-离开一个表单
  • change-在值改变后,离开表单。
  • select-在text 域中选取text
  • reset,submit.。。。

 

分享到:
评论

相关推荐

    JavaScript 在浏览器环境中的模块管理.

    JavaScript 在浏览器环境中的模块管理.,供大家一起共同分享学习。

    javascript获取浏览器临时目录

    本文将详细介绍如何在不同浏览器环境中通过JavaScript获取浏览器临时目录的方法。 #### 二、背景知识 1. **浏览器安全模型**:现代浏览器为了保护用户隐私和数据安全,采用了严格的沙箱机制和同源策略,限制了网页...

    基于JavaScript判断浏览器到底是关闭还是刷新(超准确)

    在HTML和JavaScript中,有三个关键的事件可以用来监听浏览器窗口的状态变化:`onload`、`onunload`、以及`onbeforeunload`。其中: 1. `onload`事件发生在页面加载完成后。 2. `onunload`事件发生在浏览器窗口即将...

    基于事件的JavaScript的浏览器

    在浏览器环境中,我们可以使用类似的概念来模拟这种行为,让对象能够触发自定义事件,提高代码的模块化和可扩展性。 例如,一个简单的EventEmitter实现可能如下: ```javascript class EventEmitter { ...

    浅析JavaScript中浏览器的兼容问题

    因此,开发者应当密切关注浏览器的更新,并定期更新自己的代码库,以确保网站或应用在最新的浏览器环境中仍能正常运行。 总的来说,解决JavaScript在浏览器中的兼容性问题是一个持续的过程,开发者需要不断学习和...

    JavaScript 操作键盘的Enter事件(键盘任何事件),兼容多浏览器.docx

    在多浏览器环境下,实现这种交互方式需要特殊处理。本文将介绍如何使用 JavaScript 操作键盘的 Enter 事件,兼容多浏览器。 一、什么是键盘事件? 键盘事件是指用户在键盘上进行操作所触发的事件,例如,按下键、...

    javascript解决浏览器兼容性问题

    随着不同浏览器版本的更新迭代,如何确保Web应用能够在各种浏览器环境中正常运行成为了关键所在。本文将详细介绍如何使用JavaScript解决浏览器兼容性问题,特别是针对XMLHttpRequest对象的创建及对不同版本IE浏览器...

    navigator-检测浏览器版本-javascript

    `navigator` 是全局对象的一个属性(在浏览器环境中是 `window` 的一个属性),提供了与用户浏览器有关的信息。这些信息包括浏览器名称、版本号、平台信息、语言偏好设置等。通过这些信息,开发者可以实现兼容性检测...

    javascript 多浏览器 事件大全

    JavaScript多浏览器事件大全涵盖了在不同浏览器环境下,JavaScript支持的多种事件类型及其兼容性。这些事件可以分为三大类:一般事件、页面相关事件和表单相关事件。除此之外,还有针对滚动字幕和编辑的特定事件。...

    监听浏览器文件下载事件的插件

    4. **利用浏览器扩展(插件)**:在浏览器扩展环境中,有更多的权限可以操作。例如,可以使用`chrome.downloads` API(Chrome浏览器扩展)来监听和控制文件下载。这个API允许你开始、暂停、取消下载,以及获取下载...

    JavaScript_在浏览器中增强电子书.zip

    - **Epub.js** 是一个开源的JavaScript库,专门用于在浏览器环境中解析和展示Epub格式的电子书。它支持Epub2和Epub3标准,为开发者提供了简单易用的API来集成电子书阅读功能。 - **核心功能**:Epub.js可以处理...

    Node.js-browser-run-在浏览器环境中运行代码的最简单方法

    在现代Web开发中,JavaScript不再局限于服务器端,它在浏览器环境中同样发挥着至关重要的作用。Node.js作为一个强大的JavaScript运行时,让开发者能够使用相同的语言进行后端和前端开发。然而,有时候我们需要在...

    js浏览器环境项目测试工具库

    "js浏览器环境项目测试工具库"是指专门用于在浏览器环境中对JavaScript项目进行测试的工具集合。这些工具可以帮助开发者模拟真实的浏览器环境,检测代码在不同场景下的运行效果,找出潜在的错误和性能问题。在标签...

    JavaScript的浏览器对象详解

    JavaScript是一种广泛应用于Web开发的脚本语言,它在浏览器环境中运行,为网页提供动态交互功能。浏览器对象模型(Browser Object Model,简称BOM)是JavaScript与浏览器进行交互的基础,允许我们访问和操作浏览器的...

    一个简单的EventEmitter可在浏览器中使用帮助你实现事件的订阅和发布

    `EventEmitter`是Node.js中的一个核心模块,它提供了事件发布与订阅功能,但在浏览器环境中通常需要自己实现。这个名为"一个简单的EventEmitter可在浏览器中使用帮助你实现事件的订阅和发布"的项目,就是为了解决这...

    现代浏览器的事件发射器

    使用这样的库可以在非DOM环境中(如Node.js)实现类似浏览器的事件机制。 ```javascript const Emitter = require('just-emitter-master'); let emitter = new Emitter(); emitter.on('myEvent', function(data) {...

    JavaScript_在浏览器和设备之间私下同步书签.zip

    总结来说,这个项目涉及了JavaScript的基本语法和特性,以及在浏览器环境中处理数据和通信的高级技术。通过学习和实践这个项目,开发者不仅可以提升JavaScript技能,还能了解到如何构建一个实用的跨设备数据同步解决...

    web页在微信中访问增加遮罩层 右上角弹出在浏览器中打开

    在微信中访问Web页面时,有时开发者为了提供更好的用户体验或者强制用户在浏览器环境中打开网页,会选择添加一个遮罩层,并在右上角显示“在浏览器中打开”的提示按钮。这样的设计能够确保用户能够充分利用Web页面的...

    CaptureIEEvent(浏览器事件捕获控件测试程序)

    7. **测试控件的应用**:CaptureIEEvent控件可能被用来测试网页中的JavaScript事件处理,或者验证VBScript脚本在浏览器环境下的事件响应。通过这个工具,开发者可以更准确地定位和调试与浏览器事件处理相关的问题。 ...

    javascript获取浏览器类型和版本的方法(js获取浏览器版本).docx

    JavaScript 获取浏览器类型和版本的方法 浏览器类型和版本是 web 开发中非常...获取浏览器类型和版本是一个非常重要的功能,它可以帮助开发者更好地适应不同的浏览器环境,从而提高 web 应用程序的兼容性和可用性。

Global site tag (gtag.js) - Google Analytics