《HTML教程》_7.5-7.6教学材料.pptxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

下面来分析一下如何实现上面的功能。先列出需要用到的知识点。首先,鼠标进入div触发的事件有mouseover、mouseenter事件(见7.2节),可以选择处理这两个事件改变div的背景和边框。只需要处理其中一个事件即可。

其次,鼠标移动时触发mousemove事件(见7.2节),可以处理目标div的这个事件输出鼠标指针位置和事件发生时间。第三,鼠标离开时触发mouseout、mouseleave事件(见7.2节),可以选择处理这两个事件,显示鼠标离开时指针的坐标和事件发生的时间。只需要处理其中一个事件即可。

第四,修改元素div的背景和边框需要用到控制元素样式的知识(见6.6.3节)。第五,显示鼠标指针位置X坐标和Y坐标,以及事件发生的时间需要用到MouseEvent事件对象(见7.3.2节),其中clientX和clientY表示事件发生时鼠标的位置(X和Y坐标),timeStamp属性表示事件发生的时间,以一个长整型的整数表示,需要转换成我们熟知的时间格式。

第六,要处理事件,必须注册事件处理函数。注册事件处理函数的关键是兼容两种事件处理模型(见7.5.1节)。第七,要用到事件对象,最关键也是兼容两种事件模型(见7.5.1节)。上面七点是我们实现这一功能所用到的知识点,这里并没有列出所有需要的知识点,如变量声明、控制结构,函数声明等等。

下面来看一下,这些功能是如何实现的。通过对实例功能的分析,需要实现以下功能:◆设置/添加div的黄色背景;◆设置/添加红色粗线边框;◆显示事件发生的时间以及鼠标指针的位置。◆取消/删除div的黄色背景;◆取消/删除div的红色粗线边框。

先来看一下添加div黄色背景的实现。要对div添加背景,首先要获得要添加背景的这个div。鼠标要进入或者离开这个div,那它就可以看作是事件源。通过事件对象的target属性(IE事件对象中为srcElement属性)就可以获得事件发生的事件源,也就是要设置背景的div。

根据清单7-3,获取事件对象和事件源的兼容性方法如下://获取事件对象evt varevt=eventObj||window.event; //获取对象的事件源 varelem=evt.srcElement||evt.target;

获取到事件源,也就是要设置背景的元素对象之后,就是要为它设置CSS样式,设置CSS样式的方法很多(见6.6.3节),这里采用最为简单的设置style的backgroundColor属性来实现,代码如下:elem.style.backgroundColor=yellow;

也可以使用设置style的cssText来实现,代码如下:elem.style.cssText=background-color:yellow;;最后就是显示鼠标的坐标位置和事件发生的时间,读取事件对象的clientX,clientY和timeStamp属性并构造成X=+evt.clientX+,Y=+evt.clientY+,br/+时间戳=+(newDate(evt.timeStamp))

这种格式的字符串,赋给事件源元素的innerHTML属性即可,代码如下:msg.innerHTML=X=+evt.clientX +,Y=+evt.clientY+,br/ +时间戳=+(newDate(evt.timeStamp));其中msg为显示信息div对应的变量,也就是div的元素对象。

设置背景的完整代码如下所示。functionsetBg(eventObj){ varevt=eventObj||window.event; varelem=evt.srcElement||evt.target; elem.style.backgroundColor=yellow; msg.innerHTML=X=+evt.clientX +,Y=+evt.clientY+,br/ +时间戳=+(newDate(evt.timeStamp));}

其他3个功能——设置边框、取消背景和取消边框——与此类似,不再分析其实现过程,也不再单独列出其源代码。实例的完整代码如清单7-6所示。这里省略了设置两个divCSS样式的代码,详细代码见随书源代码的Listing7-4.html文件中,它位置于第7章文件夹中。

运行效果如图7-2所示图7-2鼠标事件实例运行效果

注意这个实例代码并没有按习惯上的JavaScript代码在前,HTML标记在后的写法,而是先写出了HTML标记,然后才是JavaS

文档评论(0)

酱酱 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档