博客
关于我
js获取鼠标所在html元素的id和属性
阅读量:654 次
发布时间:2019-03-15

本文共 1603 字,大约阅读时间需要 5 分钟。

好的,本文将介绍如何使用JavaScript获取鼠标当前所在的HTML元素的id及其属性。由于部分回调函数在Firefox浏览器中可能不兼容,我们将分别提供适配方案。

使用getElementsFromPoint获取元素

在IE浏览器中,你可以直接使用以下方式:

function Get_srcElement(e) {  var srcElement = '';  // 确保在Firefox中兼容  var ee = window.event || e;  var tmpObj = ee.srcElement || ee.target;    // 获取元素的ID  var elementId = tmpObj.id;    // 获取元素的属性  var elementAttrs = tmpObj.getAttribute('data-attr') || '';    // 组合展示  srcElement += '事件srcElement.id : ' + elementId + ' 属性值 : ' + elementAttrs;    alert(srcElement);}

针对Firefox的修正方案

由于IE与Firefox在事件对象处理上有所不同,下面是优化后的版本,确保广泛兼容:

function Get_srcElement(e) {  var elementId = '';  var elementAttrs = '';    // 多浏览器兼容处理  var ee = e ? e : window.event;  var tmpObj = ee.srcElement ? ee.srcElement : ee.target;    // 获取元素的ID  elementId = tmpObj.id;    // 获取元素的属性值  elementAttrs = tmpObj.getAttribute('data-attr') || '';    // 示例输出:elementId : IDvalue, attribute : attributeValue  alert('当前元素ID : ' + elementId + '\n属性值 : ' + elementAttrs);}

这个函数通过使用window.event来兼容IE,同时直接访问srcElement来确保Firefox的支持。

配置更多事件属性

如果需要获取更多元素信息,可以扩展代码:

function Get_srcElement(e) {  var elementId = '';  var elementAttrs = '';  var tagName = tmpObj.tagName;    // 其他属性获取示例  elementAttrs += ', 类名 : ' + tmpObj.className;  elementAttrs += '\n 父元素ID : ' + tmpObj.parentElement.id;    alert('元素详情:\nID : ' + elementId + '\n标签 : ' + tagName + '\n属性值 : ' + elementAttrs);}

测试与验证

在实际应用中,可以考虑在事件触发时添加alertconsole.log来验证获取到的信息是否符合预期。

注意事项

  • 确保元素具有id属性,否则将显示null
  • 若需要更详细的事件信息,可以选择使用第三方库如dojo Venice等。
  • 对于XSS安全问题,应对idgetAttribute进行过滤或验证,避免被恶意利用。

通过以上方法,你可以在不同浏览器中实现获取鼠标所在HTML元素的id和属性。随着对CSS、DOM等技术的深入理解,你还可以进一步优化代码和功能。

转载地址:http://zjcmz.baihongyu.com/

你可能感兴趣的文章
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NIO基于UDP协议的网络编程
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>