设备中的键盘事件

任天堂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的更多相关文章

  1. JavaScript高级程序设计61.pdf

    JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...

  2. JavaScript高级程序设计60.pdf

    错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...

  3. JavaScript高级程序设计58.pdf

    15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...

  4. JavaScript高级程序设计57.pdf

    表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...

  5. JavaScript高级程序设计55.pdf

    输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...

  6. JavaScript高级程序设计54.pdf

    过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...

  7. JavaScript高级程序设计53.pdf

    共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...

  8. JavaScript高级程序设计52.pdf

    表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...

  9. JavaScript高级程序设计50.pdf

    hashchange事件 HTML5新增了hashchange事件,以便在URL的参数列表(及URL中“#”号后面的所有字符串)发生变化时通知开发人员,之所以新增这个事件,是因为在Ajax应用中,开发 ...

随机推荐

  1. C++类的成员初始化列表的相关问题

    在以下四中情况下,要想让程序顺利编译,必须使用成员初始化列表(member initialization list): 1,初始化一个引用成员(reference member): 2,初始化一个常量 ...

  2. 几个常用方法有效优化ASP.NET的性能

    一. 数据库访问性能优化 1),数据库的连接和关闭 访问数据库资源需要创建连接.打开连接和关闭连接几个操作.这些过程需要多次与数据库交换信息以通过身份验证,比较耗费服务器资源.ASP.NET中提供了连 ...

  3. 一分钟搭建Webpack+react+es6框架

    最近react刷屏的厉害,而随着它一起走进我们视野的还有webpack,webpack只是个工具,为什么如此火呢?因为简单好了不废话.   直接进入正题: 打开命令行工具: npm install - ...

  4. [About me] 关于Alima博主

    大家好,欢迎来到我的博客,我是博主Alima. 关于我,一个从岛国工作刚刚失望回国的90后男孩子,被日企伤的很难过. 迫切的想改变现在的一切,想换个城市换个工作方向,重新开始. 如果你,觉得我的博客写 ...

  5. PYTHON 获取机器硬件信息及状态

    #!/usr/bin/env python # encoding: utf-8 from optparse import OptionParser import os import re import ...

  6. 【译】4个你需要知道的Asset Catalog的秘密

    本文由CocoaChina译者 @唧唧歪歪 翻译,作者:Hector Matos 原文:4 XCODE ASSET CATALOG SECRETS YOU NEED TO KNOW 恶梦 想象你正在干 ...

  7. ABAP写的一个递归

    需求:计算下面树形结构中每个子节点与最上层父节点的对应关系. DATA:BEGIN OF lt_ztab OCCURS 0,      a  TYPE string,      b  TYPE str ...

  8. ECMall模板开发文档

    ECMall 模板开发文档 前 言 欢迎阅读 ECMall 模板制作教程,通过阅读本教程可快速上手 ECMall 模板的使用和制作. ECMall 模板制 作要求用户具备 XML . XHTML 和 ...

  9. ubuntu service

    http://blog.chinaunix.net/uid-21528208-id-2399656.html

  10. Android 向系统发送一条短信

    s //向系统写一条短信 ContentValues contentValues = new ContentValues(); contentValues.put("body",& ...