首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当禁用字段集的子元素时确定禁用状态元素

当禁用字段集的子元素时确定禁用状态元素
EN

Stack Overflow用户
提问于 2014-01-22 23:25:45
回答 2查看 1K关注 0票数 5

如果一个输入因为它是一个禁用的字段集而被禁用,IE (甚至11)似乎没有任何方法来确定它是禁用的。有什么方法可以在不搜索树的情况下确定这一点吗?

显然,我可以使用jQuery找到最近的字段集,并检查它是否已禁用,但这似乎很麻烦,更不用说潜在的昂贵了。我可以通过查看currentStyle来确定它是否已经灰暗--但这就更麻烦了。我是不是遗漏了什么?

代码语言:javascript
复制
<fieldset disabled>
  <input id="fieldset_child" type="text" value="Inherit Disabled" />
</fieldset>

<script>
  // IE 9-11 returns zero instead of one like Firefox and Chrome do
  console.log(document.querySelectorAll('#fieldset_child:disabled').length);

  // this return false in all browsers 
  console.log(document.getElementById('fieldset_child').disabled);
</script>

示例:http://jsfiddle.net/cmcnulty/ySWH2/

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-01-24 06:39:23

好的,原来Internet公开了一个名为isDisabled (http://msdn.microsoft.com/en-us/library/ie/ms533902%28v=vs.85%29.aspx)的属性,该属性是如何跟踪继承其残疾性的事物的。使用它,结合测试nodeName只检查各种表单元素,您可以很好地确定是否禁用了某些内容。未经测试的IE6-7。

票数 1
EN

Stack Overflow用户

发布于 2014-01-23 02:28:23

在IE中“继承”input并不是真正的禁用,它只是看起来是禁用的,您仍然可以在其中键入。禁用fieldset时禁用子输入的一个真正简单的方法是将disabled属性应用于单个输入。然后它们将被真正禁用,您将能够通过document.querySelectorAll找到它们。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21296253

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档