JavaScript高级程序设计48.pdf
设备中的键盘事件
任天堂Wii等设备可以通过键码知道用户按下了哪个键
复合事件
复合事件是DOM3级事件新添加的一类事件,用于处理IME的输入序列。IME(Input Method Editor,输入法编辑器)可以让用户输入在物理键盘上找不到的字符,IME通常需要同时按住多个键,但最终只输入一个字符,有3种复合事件
compositionstart:在IME的文本复合系统打开时触发,表示要开始输入了
compositionupdate:向输入字段插入新字符时触发
compositionend:在IME的文本复合系统关闭时触发,表示返回正常键盘输入状态
复合事件与文本事件很相似,在触发复合事件时,目标接收文本的输入字段。但它比文本事件对象多一个属性data,其中包含以下几个值得一个:
如果在compositionstart事件发生时访问,包含正在编辑的文本(例如,已经选中的需要马上替换的文本);
如果在compositionupdate事件发生时访问,包含正在插入的新字符;
如果在compositionend事件发生时访问,包含此次输入的所有字符
var textbox=document.getElementById("myText");
EventUtil.addHandler(textbox,"compositionupdate",function(event){
event=EventUtil.getEvent(event);
alert(event.data);
});
IE9+是2011年唯一支持复合事件的浏览器,由于缺少支持,它的用处不大
变动事件
DOM2级的变动事件能在DOM中某一部分发生变化时给出提示。变动事件是为XML或HTML DOM设计的,并不特定与某种语言。DOM2级定义如下变动事件
DOMSubtreeModified:DOM结构发生任何变化时触发,这个事件在其他任何事件触发后都会触发
DOMNodeInserted:一个节点作为子节点插入到另一个节点时触发
DOMNodeRemoved:移除节点时触发
DOMNodeInsertedIntoDocument:节点插入文档时触发,发生在DOMNodeInserted之后
DOMNodeRemovedFromDocument:节点从文档移除时触发,发生在DOMNodeRemoved之后
DOMAttrModified:特性被修改时触发
DOMCharacterDataModified:文本节点的值发生变化时触发
删除节点
使用removeChild()或replaceChild()从DOM中删除节点时首先触发DOMNodeRemoved,这个事件的目标(event.target)是被删除的节点,而event.relateNode属性中包含对目标节点的父节点的引用,这个事件触发时,节点尚未从其父节点中删除,parentNode属性仍然指向父节点,这个事件会冒泡,可以在DOM任何层次是处理它
如果被移除的节点包含子节点,那么其所有子节点以及这个被移除的节点会相继触发DOMNodeRemovedFromDocument事件,此事件不冒泡,所以必须指定其中一个子节点的事件处理程序才会被调用,这个事件的目标节点是相应的子节点或者被移除的那个节点
最后一个触发的事件是DOMSubtreeModified,事件目标是被移除节点的父节点
插入节点
使用appendChild()、replaceChild()或insertBefore()向节点插入节点时,首先触发DOMNodeInserted事件,目标节点是被插入的节点,event.relatedNode属性包含对父节点的引用,在这个事件触发时,节点已经被插到新的父节点中,此事件冒泡
然后触发DOMNodeInsertedIntoDocument事件,不冒泡,这个事件的目标是被插入的节点,最后触发DOMSubtreeModified,触发于新插入节点的父节点
EventUtil.addHandler(window,"load",function(event){
var list=document.getElementById("myList");
var item=document.createElement("li");
item.appendChild(document.createTextNode("Item 4"));
EventUtil.addHandler(document,"DOMSubtreeModified",function(event){
alert(event.type);
alert(event.target);
});
EventUtil.addHandler(document,"DOMNodeInserted",function(event){
alert(event.type);
alert(event.target);
alert(event.relatedNode);
});
EventUtil.addHandler(item,"DOMNodeInsertedIntoDocument",function(event){
alert(event.type);
alert(event.target);
});
list.appendChild(item);
});
JavaScript高级程序设计48.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应用中,开发 ...
随机推荐
- UDP协议疑难杂症全景解析
转载:http://blog.csdn.net/dog250/article/details/6896949 UDP协议疑难杂症全景解析 2011-10-22 19:26 2989人阅读 评论(4) ...
- 操作系统之进程篇(4)--经典进程间通信(IPC)问题
1. 哲学家进餐问题: 问题描述: 五个哲学家在一个圆桌上进餐,每人的面前放了一盘意大利面,两个盘子之间有一个叉子,但是由于盘子里面的面条十分光滑,需要两个叉子才能进行就餐行为.餐桌的布局如下图所示: ...
- 24种设计模式--责任链模式【Chain ofResponsibility Pattern】
中国古代对妇女制定了“三从四德”的道德规范,“三从”是指“未嫁从父.既嫁从夫.夫死从子”,也就是说一个女性,在没有结婚的时候要听从于父亲,结了婚后听从于丈夫,丈夫死了还要听儿子的,举个例子来说,一个女 ...
- centos 安装php-fpm , nginx二级域名配置 ,但为什么必须要 域名提供商 哪里解析新的二级域名一下 才能用呢?
yum -y install php-fpm php-mysql(当然还有其它扩展) /etc/init.d/php-fpm restart (重启php-fpm) /etc/php.ini (php ...
- 用source code编译安装Xdebug
1. Unpack the tarball: tar -xzf xdebug-2.2.x.tgz. Note that you do not need to unpack the tarball i ...
- php代码锁
在为台湾公司开发“保证金交易系统”的过程中,出现了这样的情况: 一个间银行有n个操作员,可以同时在系统中下单,系统需要判断银行的保证金是否足够来决定是否可以下单成功.账号保证金足够,正常下单,账号保证 ...
- hadoop2.610集群配置(包含HA和Hbase )
.修改Linux主机名2.修改IP3.修改主机名和IP的映射关系######注意######如果你们公司是租用的服务器或是使用的云主机(如华为用主机.阿里云主机等)/etc/hosts里面要配置的是内 ...
- Navicat Premium 未保存的SQL如何找回 ?
在使用 Navicat Premium 编辑SQL的过程中为防止程序意外崩溃,已经将编辑的SQL都已经备份. 备份存放目录地址:C:\Users\{登录用户名}\Documents\Navicat\M ...
- 第 9 章 模板方法模式【Template Method Pattern】
以下内容出自:<<24种设计模式介绍与6大设计原则>> 周三,9:00,我刚刚坐到位置,打开电脑准备开始干活. “小三,小三,叫一下其它同事,到会议室,开会”老大跑过来吼,带着 ...
- SDUT 2351 In Danger
点我看题目 题意 : 有n个兵想要自杀,所以他们决定围成一个圈,从1开始一直环到n,然后每第2个开始自杀,但是有一个兵不想死,所以让你编程求出最后一个应该死的人的位置,这样的话就剩他自己他可以不自杀了 ...