1.事件对象
  用来记录一些事件发生时的相关信息的对象
  A.只有当事件发生的时候才产生,只能在处理函数内部访问
  B.处理函数运行结束后自动销毁
2.如何获取事件对象
  IE: window.event
  FF: 对象.on事件 = function(e)

通用法
  var ev = e || window.event
3.事件对象的属性
 A.关于鼠标事件的事件对象
   相对浏览器位置
   clientX/clientY 当鼠标事件发生时,鼠标相对于浏览器的位置

B.相对于屏幕位置的
   screenX/screenY 当鼠标事件发生时,鼠标相对于屏幕的位置

C.相对于事件源的位置
   IE:
   offsetX/offsetY 当鼠标事件发生的时候,鼠标相对于事件源的位置
   FF:
   layerX/layerY   当鼠标发生时,鼠标相对于事件源的位置
4.键盘事件的事件对象
  keyCode // 获取键盘码  空格:32 左上右下键码:37/38/39/40
  altKey/ctrlKey/shiftKey 判断相应的键是否是按下,true/false
  type // 用来检测事件的类型

例子:

<script>

window.onload = function(){
 var but = document.getElementById("but");
 var divs = null;
 but.onclick = function(){
  if(divs != null){
   return;
  }
  divs = document.createElement("div");
  divs.style.width="300px";
  divs.style.height= "150px";
  divs.style.border = "4px solid red";
  divs.style.position = "absolute";
  var a = document.createElement("a");
  a.innerHTML = "X";
  a.style.styleFloat = "right";
  a.style.cursor = "pointer";
  divs.appendChild(a);
  document.body.appendChild(divs);

a.onclick = function(){
   document.body.removeChild(divs);
   divs = null;
  }

divs.onmousedown = function(e){
   var ok = true;
   var ev = e || window.event;
   var ox = ev.offsetX || ev.layerX;
   var oy = ev.offsetY || ev.layerY;
   this.onmousemove = function(ee){
    if(!ok){
     return;
    }
    var eev = ee || window.event;
    var cx = eev.clientX;
    var cy = eev.clientY;
    this.style.left = cx-ox+"px";
    this.style.top = cy-oy+"px";
   }
   this.onmouseup = function(){
    if(ok){
     ok = false;
    }
   }
  }

}
}
</script>

javascript 事件对象的更多相关文章

  1. 第一百二十节,JavaScript事件对象

    JavaScript事件对象 学习要点: 1.事件对象 2.鼠标事件 3.键盘事件 4.W3C与IE JavaScript事件的一个重要方面是它们拥有一些相对一致的特点,可以给你的开发提供更多的强大功 ...

  2. JavaScript事件对象与事件处理程序

    在学习之前建议请看一下事件流.事件冒泡.事件捕获 一.事件对象 事件对象:在DOM触发事件时,会产生一个事件对象event,这个事件对象包含着所有与事件相关的信息.既然event是事件对象,那么它必然 ...

  3. JavaScript事件对象

    一. 事件对象 事件处理三部分组成:对象.事件处理函数=函数.例如:单击文档任意处. 1.鼠标按钮 非 IE(W3C)中的 button 属性 0 表示主鼠标按钮(常规一般是鼠标左键) 1 表示中间的 ...

  4. JavaScript事件对象【转】

    一. 事件对象 事件处理三部分组成:对象.事件处理函数=函数.例如:单击文档任意处. 1.鼠标按钮 非 IE(W3C)中的 button 属性 0 表示主鼠标按钮(常规一般是鼠标左键) 1 表示中间的 ...

  5. Javascript 事件对象(二)event事件

    Event事件: <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" ...

  6. JavaScript事件对象与事件的委托

    事件对象 包含事件相关的信息,如鼠标.时间.触发的DOM对象等 js默认将事件对象封装好,并自动的以参数的形式,传递给事件处理函数的第1个参数,如下: document.getElementsByTa ...

  7. JavaScript 事件对象event

    什么是事件对象? 比如当用户单击某个元素的时候,我们给这个元素注册的事件就会触发,该事件的本质就是一个函数,而该函数的形参接收一个event对象. 注:事件通常与函数结合使用,函数不会在事件发生前被执 ...

  8. JavaScript事件对象属性e.target和this的区别

    前言: Event对象代表事件的状态,比如事件在其中发生的元素.键盘按键的状态.鼠标的位置.鼠标按钮的状态. 事件发生后,跟事件相关的一系列信息数据的集合都放到这个对象里面,这个对象就是事件对象eve ...

  9. Javascript 事件对象进阶(二)拖拽的应用 - 登录框的拖拽

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

随机推荐

  1. FFT(快速傅立叶算法 for java)

    package com.test.test2; public class FFT {     public static final int FFT_N_LOG = 10; // FFT_N_LOG ...

  2. HDU 4452 Running Rabbits (模拟题)

    题意: 有两只兔子,一只在左上角,一只在右上角,两只兔子有自己的移动速度(每小时),和初始移动方向. 现在有3种可能让他们转向:撞墙:移动过程中撞墙,掉头走未完成的路. 相碰: 两只兔子在K点整(即处 ...

  3. fckeditor的用法

    1.下载解压文件 2.将解压后的文件放入webroot下 3.将js引入要使用fckeditor的页面 4.用ckeditor替换textarea <@e.textarea id="t ...

  4. JBPM学习(四):执行流程实例

    概念: ProcessInstance,流程实例:代表流程定义的一次执行.如:张三昨天按请假流程请了一次假.一个流程实例包括了所有运行阶段,其中最典型的属性就是跟踪当前节点的指针,如下图. Execu ...

  5. Hyper-V避免使用快照

    虽然Hyper-V快照好处多多,但应该尽量少用,有两个原因,首先,如果你创建的是数据库服务器快照,你必须执行回滚,这样数据库往往会招到破坏,其次,创建快照会影响虚拟机的性能,实际上,创建快照就是创建第 ...

  6. Win7 64bit 安装VisualSVN出现报错:Servic 'VisualSVN Server' failed to start.解决办法

    问题描述: Win7 64bit 安装VisualSVN时出现报错: Servic 'VisualSVN Server' failed to start.Please check VisualSVN ...

  7. Mac OS X 10.7下找不到~/Library/Application Support的解决方案

    28二 最近有台机器升级到了Mac OS X 10.7,Finder的sidebar变了不说,连用户目录下的Library目录也不见了.但是Terminal中是有的,估计是被隐藏了.直接在Finder ...

  8. linux 修改文件时间

    1.ls -l *.sh 2.touch -d "10/13/2013" *.sh [我想把所以的.sh文件修改到三个月前(2013年10月13)的时间.]3.ls -l *.sh ...

  9. 普通SQL注入

    安全防御:过滤/转义非法参数,屏蔽SQL查询错误. 工具:Firefox,hackbar,sqlmap,burpsuite 1.联想tms站 例1, 联想tms站fromCity参数存在普通SQL注入 ...

  10. WWDC2016 Session笔记 – Xcode 8 Auto Layout新特性

    目录 1.Incrementally Adopting Auto Layout 2.Design and Runtime Constraints 3.NSGridView 4.Layout Feedb ...