事件驱动编程
来源:互联网 发布:七秀脸型数据 编辑:程序博客网 时间:2024/06/05 13:29
基本概念
1.事件源
事件发生的来源,
按钮、文本框等
2.事件名称
onclick、onchange、onfocus等
通常事件以on开头
3.事件处理函数
发生事件以后 调用的函数叫做事件处理函数(也叫做事件监听器)
4.事件对象
即对事件的一个具体的描述, 键盘按下事件,如果想获得用户到底按了哪个键,可以通过事件对象来获取
常用事件
一.文本框的常用事件
onfocus 获得焦点
onblur 移除焦点
二.常用的鼠标事件
onmouseover 鼠标悬停
onmouseout 鼠标移除
需求: 演示人人网登录
密码框其实一开始是文本框,获得焦点以后 使用dom技术动态产生一个密码框 然后把文本框
替换成密码框
绑定事件的三种方式
一、xhtml绑定方式
例:
<script type="text/javascript"> function test (a) { alert(a); } function test2 () { alert('test2'); } </script> </head> <body> <input type="button" name="btn1" id="btn1" value="xhtml绑定方式" onclick="test(100);test2();" /> </body>
优点:
1.写起来简单。
2.可以绑定多个函数。
3.可以传参。
缺点:
1.内容和行为没有分离,不符合W3C规范。
2.如果多个按钮都绑定一个函数test,需要一个一个绑定,比较麻烦。
3.dom编程时,动态创建的对象,就不能使用这种绑定方式了。
演示人人网登录:
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>人人网</title> <script type="text/javascript"> function mousein () { //清空 var uname = document.getElementById("username"); if (uname.value=="邮箱/手机号/用户名") { uname.value=""; } } function out () { //恢复 var uname = document.getElementById("username"); if (uname.value=="") { uname.value="邮箱/手机号/用户名"; } } function textToPwd () { var text = document.getElementById("pwd"); text.type="password"; }// function pwdToText () {// var pwd = document.getElementById("pwd");// pwd.type="text";// } </script> </head> <body> <h2>用户登录</h2> <form action="第三种绑定方式和两种事件模型(DOM2).html" method="post"> <input type="text" name="username" id="username" value="邮箱/手机号/用户名" onfocus="mousein();" onblur="out();"/><br/> <input type="text" name="pwd" id="pwd" value="" onfocus="textToPwd();" /><br/><!--onblur="pwdToText();"--> <input type="submit" name="sbmt" id="sbmt" value="提交" /> </form> </body></html>
二、dom绑定方式
基本语法:dom对象.事件 = 事件处理函数;
例:btn1.onclick = test;
示例:
<script type="text/javascript"> function test () { alert('test'); } window.onload = function(){ var btn1 = document.getElementById("btn1"); btn1.onclick = test; } </script> </head> <body> <input type="button" name="btn1" id="btn1" value="dom绑定方式" /> </body>
匿名函数:没有名字的函数。形如function(){
alert(‘test’);
}
第二中定义函数的方式:
var test = function(){
alert(‘test’);
}
立即调用的匿名函数:
函数只执行一次时,没必要给函数起名
(function(){
alert(‘test’);
})();
三、第三种绑定方式和两种事件模型
一.DOM2
dom对象.addEventListener(“click”,事件处理函数);
dom对象.removeEventListener(“click”,事件处理函数);
二.IE
dom对象.attchEvent(“onclick”,事件处理函数);
dom对.detachEvent(“onclick”,事件处理函数)
写兼容性代码
可以通过第三种绑定方式不同来判断浏览器,从而写多浏览器兼容性的代码
if(document.attachEvent){
//IE浏览器的代码
}else {
//其他浏览器的代码
}
优点:可以绑定多个事件、可以动态添加和移除事件
缺点:浏览器不兼容、必须写兼容性代码
*****************事件的传播机制*****************************
一. IE模型
只有一个阶段: 事件冒泡阶段
如果想停止事件传播
IE
event.cancelBubble = true;// 停止事件向上传播
FF
e.stopPropagation();//停止事件传播
二. DOM2(FF)
两个阶段:
1.事件捕获阶段
从外向内触发
dom对象.addEventlistener(“click”,事件处理函数,true);//给捕获阶段绑定事件
2.事件冒泡阶段
从内向外触发
dom对象.addEventlistener(“click”,事件处理函数,false);//默认值是false 给冒泡阶段绑定事件
e.stopPropagation();//停止事件向上传播
示例:
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title></title> <script type="text/javascript"> function test () { alert('test'); } function test2 () { alert('test2'); } function test3 () { if(document.attachEvent){ btn1.detachEvent("onclick",test2); }else{ btn1.removeEventListener("click",test2); } } var btn1; window.onload = function () { // btn1 = document.getElementById("btn1"); var btn2 = document.getElementById("btn2"); if(document.attachEvent){ btn1.attachEvent("onclick",test); btn1.attachEvent("onclick",test2); btn2.attachEvent("onclick",test3); }else{ btn1.addEventListener("click",test); btn1.addEventListener("click",test2); btn2.addEventListener("click",test3); } } </script> </head> <body> <input type="button" name="btn1" id="btn1" value="单击事件" /> <input type="button" name="btn2" id="btn2" value="移除btn1的test2" /> </body></html>
- 事件驱动编程
- 事件驱动编程
- Javascript事件驱动编程
- 事件驱动编程
- 关于事件驱动编程
- 事件驱动编程
- python 事件驱动编程模型
- 初识Twisted:事件驱动编程
- Lesson 3 事件驱动编程
- Node.js事件驱动编程
- dojo事件驱动编程之事件绑定
- dojo事件驱动编程之事件绑定
- 事件与状态机 事件驱动编程
- 事件驱动的JScript面对象编程
- 事件驱动的JScript面对象编程
- 事件驱动的JScript面对象编程
- 自动化测试之---Tcl事件驱动编程
- javascript之DOM事件驱动编程
- javaIPO.java
- hive 分区的详细解释
- centos7安装Mysql问题总结
- Java中hashCode的作用
- C语言之sprintf使用总结
- 事件驱动编程
- 理论经典:TCP协议的3次握手与4次挥手过程详解
- HDU1559最大子矩阵
- 过滤器
- 9.12 软件工程作业
- QT实现简单的下雪效果
- node, npm安装
- 对OpenGLES中的空间变换的理解
- 基于Vue全家桶制作的的高仿美团APP