JavaScript高级程序设计51.pdf
(续上篇)
模拟鼠标事件
var btn=document.getElementById("myBtn");
//创建事件对象
var event=document.createEvent("MouseEvents");
//初始化事件对象
event.initMouseEvent("click",true,true,document.defaultView,0,0,0,0,0,false,false,false,false,0,null);
//触发事件
btn.dispatchEvent(event);
模拟键盘事件
“DOM2级事件”草案中本来包含了键盘事件,在定稿之前又删除了,Firefox根据草案实现了键盘事件;“DOM3级事件”与删除的“DOM2级事件”有很大不同
DOM3级规定,调用createEvent()并传入“KeyboardEvent”创建一个键盘事件,返回的对象包含initKeyEvent()方法,接收下列参数
type(字符串)要触发的事件类型,“keydown”
bubbles(布尔值)是否可以冒泡
cancelable(布尔值)是否可以取消
view(AbstractView)与事件关联的视图,几乎总是设置为document.defaultView
key(布尔值)按下的键的键码
location(整数)表示按下了哪里的键,0表示默认主键盘,1表示左,2表示右,3表示数字键盘,4表示移动设备的键盘(虚拟键盘),5表示手柄
modifiers(字符串)空格分隔的修改键列表,如“shift”
repeat(整数)在一行中按了这个键多少次
DOM3级不提倡使用keypress事件,只能利用这种技术来模拟keydown和keyup事件
var textbox=document.getElementById("myTextbox"),
event;
//DOM3级事件
if(document.implementation.hasFeature("KeyboardEvent","3.0")){
event=document.createEvent("KeyboardEvent");
//初始化对象
event.initKeyboardEvent("keydown",true,true,document.defaultView,"a",0,"shift",0);
}
//触发事件
textbox.dispatchEvent(event);
以上的例子是模拟按住shift的同时按下A键
在Firefox中,调用createEvent()并传入“KeyEvents”就可以创建一个键盘事件,返回的对象包含一个initKeyEvent()方法,接收10个参数
type(字符串)要触发的事件类型,“keydown”
bubbles(布尔值)是否可以冒泡
cancelable(布尔值)是否可以取消
view(AbstractView)与事件关联的视图,几乎总是设置为document.defaultView
ctrlKey(布尔值)是否按下了Ctrl键,默认为false
altKey(布尔值)是否按下了Alt键,默认为false
shiftKey(布尔值)是否按下了Shift键,默认为false
metaKey(布尔值)是否按下了Meta键,默认为false
keyCode(整数)被按下或释放的键的键码,这个参数对keydown和keyup事件有用,默认为0
charCode(整数)通过按键生成的字符的ASCII编码,这个参数对keypress事件有用,默认为0
//只适用于Firefox
var textbox=document.getElementById("myTextbox");
//创建事件对象
var event=document.createEvent("KeyEvents");
//初始化事件对象
event.initKeyEvent("keypress",true,true,document.defaultView,false,false,false,false,65,65);
//触发事件
textbox.dispatchEvent(event);
在其他浏览器中,则需要创建一个通用的事件,然后再向事件对象中添加键盘事件特有的信息
var textbox=document.getElementById("myTextbox");
//创建事件对象
var event=document.createEvent("Events");
//初始化事件对象
event.initEvent(type,bubbles,cancelable);
event.view=document.defaultView;
event.altKey=false;
event.ctrlKey=false;
event.shiftKey=false;
event.metaKey=false;
event.keyCode=65;
event.charCode=65;
//触发事件
textbox.dispatchEvent(event);
在此必须使用通用事件,而不能使用UI事件,因为UI事件不允许向event对象添加新的属性
这样的模拟事件虽然会触发键盘事件,但却不会向文本框中写入文本,这是由于无法精确模拟键盘事件造成的
模拟其他事件
模拟变动事件createEvent("MutationEvents"),包含initMutationEvent()方法的变动事件对象,接收type、bubbles、cancelable、relatedNode、preValue、newValue、attrName和attrChange
模拟HTML事件(如“focus”),createEvent("HTMLEvents"),initEvent()初始化
浏览器很少使用变动事件和HTML事件,因为它们会受到一些限制
自定义DOM事件
自定义事件不是由DOM原生触发的,它的目的是让开发人员创建自己的事件createEvent("CustomEvent"),返回的对象有一个initCustomEvent()方法,接收4个参数
type(字符串)触发的事件类型
bubbles(布尔值)事件是否可以冒泡
cancelable(布尔值)事件是否可以取消
detail(对象)任意值,保存在event对象的detail属性中
var div=document.getElementById("myDiv"),
event;
EventUtil.addHandler(div,"myevent",function(event){
alert("DIV:"+event.detail);
});
EventUtil.addHandler(document,"myevent",function(event){
alert("DOCUMENT:"+event.detail);
});
if(document.implementation.hasFeature("CustomEvents","3.0")){
event=document.createEvent("CustomEvent");
event.initCustomEvent("myevent",true,false,"Hello world!");
div.dispatchEvent(event);
}
支持自定义事件的浏览器有IE9+和Firefox6+
IE中的模拟事件
IE8之前的版本模拟事件与DOM中的思路相似:创建event对象,指定相应信息,触发事件
var btn=document.getElementById("myBtn");
//创建事件对象(不接受参数)
var event=document.createEventObject();
//添加必要信息
event.screenX=100;
event.screenY=0;
event.clientX=0;
event.clientY=0;
event.ctrlKey=false;
event.altKey=false;
event.shiftKey=false;
event.button=0;
//触发事件(接收事件处理程序的名称和event对象2个参数),fireEvent()方法会自动为event对象添加srcElement和type属性
textbox.fireEvent("onkeypress",event);
与通用事件一样,这个例子触发了事件处理程序却不会在文本框中看到任何字符
-----------------------------------13章事件结束-----------------------------------
JavaScript高级程序设计51.pdf的更多相关文章
- JavaScript高级程序设计61.pdf
JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...
- JavaScript高级程序设计60.pdf
错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...
- JavaScript高级程序设计58.pdf
15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...
- JavaScript高级程序设计57.pdf
表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...
- JavaScript高级程序设计55.pdf
输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...
- JavaScript高级程序设计54.pdf
过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...
- JavaScript高级程序设计53.pdf
共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...
- JavaScript高级程序设计52.pdf
表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...
- JavaScript高级程序设计50.pdf
hashchange事件 HTML5新增了hashchange事件,以便在URL的参数列表(及URL中“#”号后面的所有字符串)发生变化时通知开发人员,之所以新增这个事件,是因为在Ajax应用中,开发 ...
随机推荐
- Java LoggingAPI 使用方法
因为不想导入Log4j的jar,项目只是测试一些东西,因此选用了JDK 自带的Logging,这对于一些小的项目或者自己测试一些东西是比较好的选择. Log4j中是通过log4j.properties ...
- MySQL配置文件详解
MYSQL 配置文件详解 “全局缓存”.“线程缓存”,全局缓存是所有线程共享,线程缓存是每个线程连接上数据时创建一个线程(如果没有设置线程池),假如有200连接.那就是200个线程,如果参数设定值是1 ...
- 2015-01-27-从实验出发理解buffer与cache区别-吴伟顺
通过du(find) 与 cat 体现buffer与cache差异实验: 实验表明: 1 通常 buffer << cache 2 "文件系统"相关内容(ino ...
- 浅谈页面无刷新技术ajax
现在一般网站都是用ajax来实现页面无刷新操作的. 什么是无刷新:ajax可以实现页面与后台的数据交互,用户完全感觉不出页面有任何的刷新,这就是AJAX的无刷新. ajax方法实现: 可以对ajax进 ...
- cenots 下的 lamp(备份与恢复)
用 putty连接数据库: mysql -uroot -p密码 create database yourdb DEFAULT CHARACTER SET utf8 COLLATE utf8_chine ...
- php hook 之简单例子
<?php// 应用单例模式// 建立相应的 plugins 文件夹,并建立 .php 文件放在里面class plugin{ public $actions; public $fi ...
- ES6 语法简介
参考: http://es6.ruanyifeng.com/ 总结学习 JavaScript语言下一代标准,2015年6月正式发布. 1.let和const命令 let用作变量声明,只在代码块内有效 ...
- 欢迎使用skymvc框架,简单易用的php框架
skymvc是一款轻量.简单易用的php mvc框架,经过多个项目实践改良. 特点: 1.mvc架构 2.m.v.c之间可以互相调用 3.简单的路由控制 R("/index.php" ...
- PHP学习笔记(2) - 对PHP的印象
一.PHP是一种简单易学的面向过程的弱类型动态脚本语言,本为制作简单的个人网站而开发,现如今经过多个版本的衍变甚至加入了一些面向对象的特性.PHP试图通过发展打进企业级开发,同时也使得它自身也越来越复 ...
- http 常用状态码及含义
http://www.kuaipan.cn/developers/document_status.htm