如何查看标签元素对象中属性的属性描述符?

新手上路,请多包涵

在页面中某一标签,例如div(id="test"),获取它的js对象后,var obj =
document.getElementById("test"),我想查看它某个属性的属性描述符,但是返回是undefined,在此请教各位前辈。
Object.getOwnpropertyDescriptor(obj, "attributes"); 返回的是undefined

阅读 2.4k
1 个回答

测试了一下,发现确实是返回undefined,下面是我的思维过程:

  1. Object.getOwnPropertyDescriptor从方法名可以看出来,这个属性必须是自有属性,而不是原型链上的属性,那么是不是attributes并不是dom元素的自有属性呢?
  2. 使用Object.hasOwnProperty验证一下,果然返回了false。既然不是自有属性,那么Object.getOwnPropertyDescriptor也就返回undefined了。但是为什么不是自有属性呢?
  3. 使用Object.hasOwnPropertyobj原型链上的对象测试了一遍,都是返回false
  4. 结论:可能是dom对象做了特殊处理。那么我还是想看这个属性描述符怎么办呢?
  5. 既然attributes不是obj的自有属性,那么我自己创建一个js对象,然后设置attributes属性是obj.attributes应该就行了吧?
  6. 果然,出来了。验证截图如下:

clipboard.png

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题