javascript 事件对象
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 事件对象的更多相关文章
- 第一百二十节,JavaScript事件对象
JavaScript事件对象 学习要点: 1.事件对象 2.鼠标事件 3.键盘事件 4.W3C与IE JavaScript事件的一个重要方面是它们拥有一些相对一致的特点,可以给你的开发提供更多的强大功 ...
- JavaScript事件对象与事件处理程序
在学习之前建议请看一下事件流.事件冒泡.事件捕获 一.事件对象 事件对象:在DOM触发事件时,会产生一个事件对象event,这个事件对象包含着所有与事件相关的信息.既然event是事件对象,那么它必然 ...
- JavaScript事件对象
一. 事件对象 事件处理三部分组成:对象.事件处理函数=函数.例如:单击文档任意处. 1.鼠标按钮 非 IE(W3C)中的 button 属性 0 表示主鼠标按钮(常规一般是鼠标左键) 1 表示中间的 ...
- JavaScript事件对象【转】
一. 事件对象 事件处理三部分组成:对象.事件处理函数=函数.例如:单击文档任意处. 1.鼠标按钮 非 IE(W3C)中的 button 属性 0 表示主鼠标按钮(常规一般是鼠标左键) 1 表示中间的 ...
- Javascript 事件对象(二)event事件
Event事件: <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" ...
- JavaScript事件对象与事件的委托
事件对象 包含事件相关的信息,如鼠标.时间.触发的DOM对象等 js默认将事件对象封装好,并自动的以参数的形式,传递给事件处理函数的第1个参数,如下: document.getElementsByTa ...
- JavaScript 事件对象event
什么是事件对象? 比如当用户单击某个元素的时候,我们给这个元素注册的事件就会触发,该事件的本质就是一个函数,而该函数的形参接收一个event对象. 注:事件通常与函数结合使用,函数不会在事件发生前被执 ...
- JavaScript事件对象属性e.target和this的区别
前言: Event对象代表事件的状态,比如事件在其中发生的元素.键盘按键的状态.鼠标的位置.鼠标按钮的状态. 事件发生后,跟事件相关的一系列信息数据的集合都放到这个对象里面,这个对象就是事件对象eve ...
- Javascript 事件对象进阶(二)拖拽的应用 - 登录框的拖拽
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
随机推荐
- FFT(快速傅立叶算法 for java)
package com.test.test2; public class FFT { public static final int FFT_N_LOG = 10; // FFT_N_LOG ...
- HDU 4452 Running Rabbits (模拟题)
题意: 有两只兔子,一只在左上角,一只在右上角,两只兔子有自己的移动速度(每小时),和初始移动方向. 现在有3种可能让他们转向:撞墙:移动过程中撞墙,掉头走未完成的路. 相碰: 两只兔子在K点整(即处 ...
- fckeditor的用法
1.下载解压文件 2.将解压后的文件放入webroot下 3.将js引入要使用fckeditor的页面 4.用ckeditor替换textarea <@e.textarea id="t ...
- JBPM学习(四):执行流程实例
概念: ProcessInstance,流程实例:代表流程定义的一次执行.如:张三昨天按请假流程请了一次假.一个流程实例包括了所有运行阶段,其中最典型的属性就是跟踪当前节点的指针,如下图. Execu ...
- Hyper-V避免使用快照
虽然Hyper-V快照好处多多,但应该尽量少用,有两个原因,首先,如果你创建的是数据库服务器快照,你必须执行回滚,这样数据库往往会招到破坏,其次,创建快照会影响虚拟机的性能,实际上,创建快照就是创建第 ...
- Win7 64bit 安装VisualSVN出现报错:Servic 'VisualSVN Server' failed to start.解决办法
问题描述: Win7 64bit 安装VisualSVN时出现报错: Servic 'VisualSVN Server' failed to start.Please check VisualSVN ...
- Mac OS X 10.7下找不到~/Library/Application Support的解决方案
28二 最近有台机器升级到了Mac OS X 10.7,Finder的sidebar变了不说,连用户目录下的Library目录也不见了.但是Terminal中是有的,估计是被隐藏了.直接在Finder ...
- linux 修改文件时间
1.ls -l *.sh 2.touch -d "10/13/2013" *.sh [我想把所以的.sh文件修改到三个月前(2013年10月13)的时间.]3.ls -l *.sh ...
- 普通SQL注入
安全防御:过滤/转义非法参数,屏蔽SQL查询错误. 工具:Firefox,hackbar,sqlmap,burpsuite 1.联想tms站 例1, 联想tms站fromCity参数存在普通SQL注入 ...
- WWDC2016 Session笔记 – Xcode 8 Auto Layout新特性
目录 1.Incrementally Adopting Auto Layout 2.Design and Runtime Constraints 3.NSGridView 4.Layout Feedb ...