如何避免使用CSS属性选择器的JavaScript
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了如何避免使用CSS属性选择器的JavaScript,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1830字,纯文字阅读大概需要3分钟。
内容图文
![如何避免使用CSS属性选择器的JavaScript](/upload/InfoBanner/zyjiaocheng/784/b10f3f00dc12441aa8f1cf76455a3551.jpg)
我试图用role =“metadata”和与第一个发生的tr相同的data-group-id隐藏后续的tr.
我不能在这里使用JavaScript,我试图使用纯CSS实现这一点.
<table>
<tbody>
<!-- BEGIN this tr should be visible -->
<tr data-group-id="1" role="metadata">
<td>
First rows group title
</td>
</tr>
<!-- END this tr should be visible -->
<tr data-group-id="1" role="data">
<td>
Row belonging to group 1
</td>
</tr>
<!-- BEGIN this tr should be hidden -->
<tr data-group-id="1" role="metadata">
<td>
Rows group title
</td>
</tr>
<!-- END this tr should be hidden -->
<tr data-group-id="1" role="data">
<td>
Another row belonging to group 1
</td>
</tr>
<!-- BEGIN this tr should be visible -->
<tr data-group-id="2" role="metadata">
<td>
Second rows group title
</td>
</tr>
<!-- END this tr should be visible -->
<tr data-group-id="2" role="data">
<td>
Row belonging to group 2
</td>
</tr>
</tbody>
</table>
这样的选择器……
[data-group-id="1"][role~="metadata"] ~ [data-group-id="1"][role~="metadata"]
display: none
…工作得很好,除了data-group-id可能会动态变化.
像这样的东西是完美的(我知道这是无效的CSS代码,它只是我的幻想与正则表达式,以帮助说明问题):
[data-group-id="(.*?)"][role~="metadata"] ~ [data-group-id="\\1"][role~="metadata"]
有没有什么办法可以用CSS来实现这个目的?
提前致谢.
解决方法:
在我看来,在CSS中使用data-group-id是不切实际的,特别是因为它是动态可变的,并且隐藏或不改变元素的条件.你最终得到了一大堆无法维护的CSS.
在初始渲染中,最好添加一个className,以便确定应该显示初始状态的服务器端.
<tr data-group-id="1" role="data" class="hidden">
<td>Another row belonging to group 1</td>
</tr>
我假设JavaScript用于动态更改data-group-id,所以为什么不在有意义的时候使用JavaScript来添加/删除className“hidden”.至少在JavaScript中你可以使用正则表达式;)
当你到达必须编写不可能的,冗长的,容易出错且不可维护的CSS表达式时,你做错了什么.
无论如何,你将不得不编写一些代码来实现这一点,不妨尝试将它变成一种不适合工作的样式语言.
内容总结
以上是互联网集市为您收集整理的如何避免使用CSS属性选择器的JavaScript全部内容,希望文章能够帮你解决如何避免使用CSS属性选择器的JavaScript所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。