- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 肿瘤科护理一科一品成果.pptx VIP
- 华为DSTE战略管理体系完整版1.pptx VIP
- 喷锚支护计算书.doc VIP
- 2025新修订《治安管理处罚法》应知应会100题(含答案+解析).pdf
- 新外研版必修三单词默写表(附参考答案).docx VIP
- 《制冷和空调设备基础与技能》单元2 全封闭活塞式制冷压缩机的拆卸、检测与维修 教学课件.pptx VIP
- 《万以内数的认识:整理和复习》教学设计-2025-2026学年人教版(新教材)小学数学二年级下册.docx
- JHD系列商业卫星用56Gbps矩形高速IO连接器.pdf VIP
- EtherCAT总线在运动控制系统的应用.ppt VIP
- 2026届湖南省衡阳市第一中学物理高二上期末监测试题含解析.doc
原创力文档


文档评论(0)