JS事件
JS事件:
声明:为了事件对象event跨浏览器兼容: var oEvent==ev||event;
所以在下面用到 event 的地方都用 oEvent 代替
1)doucument的本质:是整个文档的根节点,所有的html都包含在document里面,
不过我们平时都是省略document
document.childNodes[0].tagName-->!
document.childNodes[1].tagName-->html
2)事件对象:即event对象
在触发DOM上的某个事件时,会产生一个事件对象event,这个对象中包含着所有与事件相关的信息
如:获取鼠标的位置,获取键盘按键
如:不同浏览器下的事件对象:
IE/Chrom: event
FF/IE9+/Chrom: 传参ev
跨浏览器的事件对象兼容性写法:var oEvent==ev||event;
document.oncilck=function(ev){
var oEvent==ev||event;
if(oEvent){
alert(oEvent.clientX);
}
}
3)事件类型:
1.window上面的事件:
--window.onload:当页面完全加载完后就会触发onload事件
--window.onunload:与onload事件相对应,当文档被完全卸载后触发
--window.onresize:当浏览器窗口大小被改变期间被重复触发
--window.onscroll:在文档被滚动期间重复触发
2.焦点事件:
--element.onblur:元素失去焦点时触发
--element.onfocus:元素获得焦点时触发
3.鼠标事件:
--elelment.onclick:当用户点击某个对象时触发
--element.ondblclick:当用户双击某个对象时触发
--elelment.onmousedown:鼠标按键被按下时触发
--element.onmouseup:鼠标按键被松开时触发
--element.onmousemove:当鼠标移动时触发
--element.onmouseover:鼠标移到某元素之上时触发
--element.onmouseout:鼠标从某元素上面移开时触发
4.鼠标事件的属性:
1.--oEvent.button=0|1|2: 当事件被触发时哪个鼠标按键被点击
非IE下:
0 表示鼠标左键被点击
1 表示鼠标中键被点击
2 表示鼠标右键被点击
IE下:
1 表示鼠标左键被点击
4 表示鼠标中键被点击
2 表示鼠标右键被点击
2.--oEvent.clientX,oEvent.clientY:获取鼠标在可视区的相对位置,
即参照点在浏览器的左上角,会随着滚动条的滚动而变化,在没有滚动条时,
直接oEvent.clientX,oEvent.clientY即可获取鼠标位置,当有滚动条时,则不能直接使用
所以获取鼠标的绝对位置可以封装成一个函数:(页面有无滚动条时都可以用)
function getMousePosition(ev){
var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;
var scrollLeft=document.documentElement.scrollLeft||document.body.scrollLeft;
return {x:ev.clientX+scrollLeft,y:ev.clientY+scrollTop};
}
例子2:让一个div跟随鼠标运动:
document.onmousemove=function(ev){
var oEvent==ev||event;
var pos=getMousePosition(oEvent);
if(oEvent){
oDiv.style.top=pos.y+'px';
oDiv.style.left=pos.x+'px';
}
}
例子2:一串div跟随鼠标移动
(html是很多宽和高都很小的div)
window.onload=function(ev){
var oDiv=document.getElementsByTagName('div');
var oEvent=ev||event;
var pos=getMousePosition(oEvent);
for(var i=oDiv.length-1;i>0;i--){ //让后一个div跟着前一个运动
oDiv[i].style.left=oDiv[i-1].offsetLeft+'px';
oDiv[i].style.top=oDiv[i-1].offsetTop+'px';
}
//让第0个div跟着鼠标运动
oDiv[0].style.top=pos.x+'px';
oDiv[0].style.left=pos.y+'px';
}
3.--oEvent.page.X, oEvent.pageY: 获取的是鼠标的绝对位置,参照点是浏览器的左上角,
与上面的getMousePosition函数的作用一样,但是IE8及以下不兼容,所以一般不使用,
获取鼠标的绝对位置还是使用getMousePosition函数
4.--oEvent.screenX, oEvent.screenY: 获取的是屏幕坐标的位置,参照点是屏幕的左上角,而不是浏览器左上角
总结:
1.screenX, clientX, pageX三者的区别:
--screenX:鼠标位置相对于用户屏幕水平偏移量,而screenY也就是垂直方向的,此时的参照点也就是原点是屏幕的左上角
--clientX:跟screenX相比就是将参照点改成了浏览器内容区域的左上角,该参照点会随之滚动条的移动而移动
--pageX:参照点也是浏览器内容区域的左上角,但它不会随着滚动条而变动(不兼容,所以还是使用clientX方法获取鼠标位置)
2.只要用到event.clientX,event.clientY,obj.clientWidth,obj.clientHeight都要用到scrollTop/scrollLeft
5.键盘事件:
--element.onkeydown:某个键盘按键被按下触发
--element.onkeyup:某个键盘按键被松开时触发
6.键盘事件的属性:
1.修改键:是指Shift,Ctrl,Alt,Meta(Windows中指win键,苹果机中指Cmd键)
这些修改键经常用来修改鼠标事件的行为,所以DOM为此规定了四个属性,
表示这些修改键的状态,更别为:shiftKey,ctrlKey,altKey,metaKey
这些属性返回的都是布尔值,当相应的键被按下时,返回true,否则返回false
使用表示:
--oEvent.shiftKey
--oEvent.ctrlKey
--oEvent.altKey
--oEvent.metaKey
ctrl+enter提交留言:
windown.onload=function(ev){
var oEvent=ev||event;
var otxt=document.getElementById('txt');
txt.onkeydown=function(){
if(oEvent.keyCode==13 && oEvent.ctrlKey){
otxtArea.value+=otxt.value;
otxt.value='';
}
}
}
2.keyCode属性:
--oEvent.keyCode可以获取鼠标的键码,也可以根据键码,判断用户按下的是哪一个按键
--在键盘控制或者是鼠标控制运动的过程中,必须要给绝对定位,才能运动
document.onkeydown=function(ev){
var oEvent=ev||event;
if(oEvent.keyCode==37){
oDiv.style.left=oDiv.offsetLeft-10+'px';
}else if(oEvent.keyCode==39){
oDiv.style.left=oDiv.offsetLeft+10+'px';
}
}
7.文本事件:
1.element.onchange: 当输入域的内容改变时触发
一般适用于文本域(text field),以及 textarea 和 select 元素
<input type="text" value="Hello world!" onchange="this.value='abccdef';" />
或者: oTxt.onchange=function(){
this.value='abccdef';
}
2.element.onselect:文本被选中时触发
<input type="text" value="Hello world!" onselect="alert('selected text')" />
8.其他事件:
--element.onabort:图像的加载被中断时触发
--element.onerror:在加载文档或图像时发生错误时触发
--element.onreset:重置按钮被点击时触发
--element.onsubmit:确认按钮被点击时触发
--element.oncontextmenu:自定义右键菜单事件,有返回值
9.补充:
--什么是浏览器的默认行为:浏览器自己本身就有的一些事件,
如在页面中我们点击右键,会出来一个浏览器自己的右键菜单; 我们在文本框中输入内容也是一种默认行为
--阻止默认行为:return false;-->会阻止浏览器所有的默认行为
示例1:只能输入数字的文本框
var oTxt=document.getElementById('txt');
oTxt.onkeydown=function(ev){
var oEvent=ev||event;
if(oEvent.keyCode!=8 && (oEvent.keyCode<48||oEvent.keyCode>57)){
return false;
}
}
有时候我们需要阻止默认行为,自己定义一个右键菜单出来:
例子2:右键弹出自己自定义的菜单(自己定义oDiv的样式)
document.oncontextmenu=function(ev){
var oEvent=ev||event;
return false; //阻止浏览器默认的浏览器右键菜单
oDiv.style.display='black';
oDiv.style.left=oEvent.clientX; //没有滚动条的情况
oDiv.style.top=oEvent.clientY;
}
document.onclick=function(){
oDiv.style.display='none'; //单击页面其他位置,自定义菜单消失
}
4)多事件绑定: attachEvent/attachEventLister
当页面中有两个window.onload时,页面会只执行第二个
有时我们希望两个相同的函数都能执行,这里需要事件绑定
1)事件绑定:(不兼容需要两个结合做兼容if..else..)
IE8以下用: attachEvent('事件名',fn);
FF,Chrome,IE9-10用: attachEventLister('事件名',fn,false);
同一对象绑定两个相同事件,两个事件都会执行
if(oBtn.attachEvent){
oBtn.attachEvent('onclick',function(){
alert('a');
});
oBtn.attachEvent('onclick',function(){
alert('b');
});
}else{
oBtn.attachEventLister('click',function(){
alert('a');
},false);
oBtn.attachEventLister('click',function(){
alert('b');
},false);
}
多事件绑定封装成一个兼容函数:
function myAddEvent(obj,ev,fn){
if(obj.attachEvent){
obj.attachEvent('on'+ev,fn);
}else{
obj.attachEventLister(ev,fn,false);
}
}
myAddEvent(oBtn,'click',function(){
alert(a);
});
myAddEvent(oBtn,'click',function(){
alert(b);
});
2)解除绑定:
IE:detachEvent('事件名',fn);
FF,Chrome,IE9-10:removeEventLister('事件名',fn,false);
JS事件的更多相关文章
- dynamic-css 动态 CSS 库,使得你可以借助 MVVM 模式动态生成和更新 css,从 js 事件和 css 选择器的苦海中脱离出来
dynamic-css 使得你可以借助 MVVM 模式动态生成和更新 css,从而将本插件到来之前,打散.嵌套在 js 中的修改样式的代码剥离出来.比如你要做元素跟随鼠标移动,或者根据滚动条位置的变化 ...
- 什么是JS事件冒泡?
什么是JS事件冒泡?: 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理 程序或者事件返回true,那么 ...
- js事件技巧方法整合
window.resizeTo(800,600); //js设置浏览器窗口尺寸 window.open (function(){ resizeTo(640,480);//设置浏览器窗口尺寸 moveT ...
- js事件浅析
js中关于DOM的操作很多,因此js事件机制也就尤为重要. 事件绑定形式: 一. 内联形式 耦合度高,不利于维护 <button onclick="alert('你点击了这个按钮'); ...
- js 事件大全
Js事件大全一般事件 事件 浏览器支持 描述onClick IE3|N2|O3 鼠标点击事件,多用在某个对象控制的范围内的鼠标点击onDblClick IE4|N4|O 鼠标双击事件onMouseDo ...
- 原生JS事件绑定方法以及jQuery绑定事件方法bind、live、on、delegate的区别
一.原生JS事件绑定方法: 1.通过HTML属性进行事件处理函数的绑定如: <a href="#" onclick="f()"> 2.通过JavaS ...
- 原生js事件和jquery事件的执行顺序问题
场景:近日,写前端页面时候,在针对输入框input操作时,用到了jquery的插件,插件中使用了jquery的focus()和blur()方法.但是同时,又需要在插件之外再针对输入框的获取焦点和失去焦 ...
- 特殊js事件
1:点击enter事件 $(document).keypress(function(e) { // 回车键事件 if(e.which == 13) { submitForm(); } }); 2:JQ ...
- js 事件
事件:一般用于浏览器与用户操作进行交互 js事件的三种模型:内联模型.脚本模型.DOM2模型 内联模型:事件处理函数是HTML标签的属性 <input type="button&quo ...
随机推荐
- C# String 前面不足位数补零的方法
int i=10;方法1:Console.WriteLine(i.ToString("D5"));方法2:Console.WriteLine(i.ToString().PadLef ...
- Windows重启网络命令
netsh winsock reset ipconfig /flushdns
- Python 打包工具cx_freeze 问题记录及解决办法
在节前的最后一天,解决了打包过程中遇到的所有问题,可以成功运行了!真是个好彩头,希望新的一年一切顺利! 以下是在使用cx_freeze过程中遇到的问题及解决办法(Win7) 问题描述:运行exe,启动 ...
- Stripe开发笔记之-ISO Currency Code(ISO 4217)
参考:维基百科和ISO官网 ISO Currency Code:国际标准组织通用货币代号,国际标准化组织(英语:International Organization for Standardizati ...
- wordpress取文章时间
wordpress的时间处理, 取文章的本地时间用get_the_time('c'),其中c可以用“D, d M Y H:i:s"等替代. 取文章的UTC时间用get_post_time(' ...
- [转]Android - 文件读写操作 总结
转自:http://blog.csdn.net/ztp800201/article/details/7322110 Android - 文件读写操作 总结 分类: Android2012-03-05 ...
- 《storm实战-构建大数据实时计算读书笔记》
自己的思考: 1.接收任务到任务的分发和协调 nimbus.supervisor.zookeeper 2.高容错性 各个组件都是无状态的,状态 ...
- ASP.NET TextBox 当鼠标点击后清空默认提示文字[转]
前台文本框里添加下面2个事件属性: OnFocus="javascript:if(this.value=='提示文字') {this.value=''}" OnBlur=" ...
- java中一些定时器的使用
一:简单说明 ScheduleExecutorService接口中有四个重要的方法,其中scheduleAtFixedRate和scheduleWithFixedDelay在实现定时程序时比较方便. ...
- 基于C#和Asp.NET MVC开发GPS部标监控平台
基于交通部796标准开发部标监控平台,选择开发语言和技术也是团队要思考的因素,其实这由团队自己擅长的技术来决定,如果擅长C#和Asp.NET, 当然开发效率就高很多.当然了技术选型一定要选用当前主流的 ...