JS事件(二)事件对象
html事件处理程序中,变量event中保存着事件对象
- <button onclick="alert(ev.type)" id="btn">click</button>
1、DOM中的事件对象
无论是DOM0还是DOM2,事件处理程序中都会传入一个event对象
- var btn=document.getElementById("btn");
- btn.onclick=function(){
- alert(1);
- }
- btn.addEventListener("click",function(ev){
- alert(ev.type);
- },false);
所有的事件都会有下表列出的成员:
在事件处理程序内部,对象this始终等于currentTarget的值,而target是事件实际目标
stopPropagation用于立即停止事件在DOM层中的传播:
- var btn=document.getElementById("btn");
- btn.onclick=function(event){
- alert("btn");
- event.stopPropagation();
- }
- document.body.onclick=function(event){
- alert("body");//不会执行
- }
2、IE中的事件对象
访问IE中的event对象的方式取决于指定事件处理程序的方法
2.1、DOM0级:
IE8-浏览器不识别传入的event对象,需要在事件处理函数内部声明
- var btn=document.getElementById("btn");
- btn.onclick=function(event){
- alert(window.event.type);
- }
IE9+浏览器以及其他高级浏览器则是两种方式都支持
2.2、attachEvent:
支持传入event参数
所有的事件都会有下表列出的成员:
this不一定指向目标元素,也可能指向全局(attachEvent),故用event.srcElement比较保险
兼容浏览器的事件处理对象:
- var EventUtil={
- addHandler:function(element,type,handler){
- if(element.addEventListener){
- element.addEventListener(type,handler,false);
- }
- else if(element.attachEvent){
- element.attachEvent('on'+type,handler);
- }
- else{
- element['on'+type]=handler;
- }
- },
- removeHandler:function(element,type,handler){
- if(element.removeEventListener){
- element.removeEventListener(type,handler,false);
- }
- else if(element.detachEvent){
- element.detachEvent('on'+type,handler);
- }
- else{
- element['on'+type]=null;
- }
- },
- getEvent:function(event){
- return event ? event : window.event;
- },
- getTarget:function(event){
- return event.target || event.srcElement;
- },
- preventDefault:function(event){
- if(event.preventDefault){
- event.preventDefault();
- }
- else{
- event.returnValue=false;
- }
- },
- stopPropagation:function(event){
- if(event.stopPropagation){
- event.stopPropagation();
- }
- else{
- event.cancelBubble=true;
- }
- }
- }
JS事件(二)事件对象的更多相关文章
- HTML 事件(二) 事件的注册与注销
本篇主要介绍HTML元素事件的注册.注销的方式. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流.事件委托 4. ...
- JS基础(二)事件监听练习之table鼠标悬停行变色
JS监听事件简单学习: [object].addEvent("事件类型","处理函数","冒泡事件或捕获事件"); [object].r ...
- vue事件获取当前对象
一.事件传参 如点击事件 <div @click='click'> <div> <div @click='click_1('msg')'> <div> ...
- HTML 事件(一) 事件的介绍
本篇主要介绍HTML中的事件知识:事件相关术语.DOM事件规范.事件对象. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三 ...
- HTML 事件(三) 事件流与事件委托
本篇主要介绍HTML DOM中的事件流和事件委托. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4 ...
- 从零开始的JS生活(二)——BOM、DOM与JS中的事件
上回书说道,JS中变量.运算符.分支结构.循环和嵌套循环等内容.本回就由本K给大伙唠唠JS中的BOM.DOM和事件. 一."花心大萝卜"--BOM 1.震惊,FFF团为何对BOM举 ...
- js中的事件,内置对象,正则表达式
[JS中的事件分类] 1.鼠标事件: click/dbclick/mouseover/mouseout/mousemove/mousedown/mouseup 2.键盘事件: keydown: 键盘按 ...
- JS中的事件&对象
一.JS中的事件 (一)JS中的事件分类 1.鼠标事件 click/dblclick/onmouseover/onmouseout 2.HTML事件 onload/onscroll/onsubmit/ ...
- JS基础--函数与BOM、DOM操作、JS中的事件以及内置对象
前 言 絮叨絮叨 这里是JS基础知识集中讲解的第三篇,也是最后一篇,三篇JS的基础,大多是知识的罗列,并没有涉及更难得东西,干货满满!看完这一篇后,相信许多正在像我一样正处于初级阶段的同学, ...
- python 全栈开发,Day55(jQuery的位置信息,JS的事件流的概念(重点),事件对象,jQuery的事件绑定和解绑,事件委托(事件代理))
一.jQuery的位置信息 jQuery的位置信息跟JS的client系列.offset系列.scroll系列封装好的一些简便api. 一.宽度和高度 获取宽度 .width() 描述:为匹配的元素集 ...
随机推荐
- 十、ABP
一.官网 安装 安装成功Core 2.2版本的
- C#使用WebClient下载文件到本地目录
C#使用WebClient下载文件到本地目录. 1.配置本地目录路径 <appSettings> <!--文件下载目录--> <add key="Downloa ...
- react 入坑笔记(五) - 条件渲染和列表渲染
条件渲染和列表渲染 一.条件渲染 条件渲染较简单,使用 JavaScript 操作符 if 或条件运算符来创建表示当前状态的元素,然后让 React 根据它们来更新 UI. 贴一个小栗子: funct ...
- 集成Javascript Logging on MVC or Core
ASP.NET Core provides us a rich Logging APIs which have a set of logger providers including: Console ...
- c++ string类型的定义及方法
1.c++ 有两种风格的字符串形式 c风格字符串 定义及初始化 char a[]={'h','e','l','l','o','\0'} 或者 char a[]="hello&quo ...
- codeforces24D
CF24D Broken robot 题目背景 小小迪带你吃瓜 题目描述 给出一个 n×m 的矩阵区域,一个机器人初始在第 x 行第 y 列,每一步机器人会等概率 的选择停在原地,左移一步,右移一步, ...
- Nginx 模块分类
L:34
- 进程间通讯:有名管道FIFO
接收端: #include <sys/stat.h> #include <sys/types.h> #include <stdio.h> #include < ...
- 洛谷P2084 进制转换
题目背景 无 题目描述 今天小明学会了进制转换,比如(10101)2 ,那么它的十进制表示的式子就是 : 1*2^4+0*2^3+1*2^2+0*2^1+1*2^0, 那么请你编程实现,将一个M进制的 ...
- Java 属性映射(DozerBeanMapper)
package com.kps.common.utils; import java.util.ArrayList; import java.util.Collection; import java.u ...