html隐藏该元素的功能,html – 带有可见的隐藏元素:after – CSS

我猜这是因为大卫托马斯认为伪元素是不可见的,因为它是’父元素’.它在其他浏览器中工作的原因可以通过不同的实现来解释,其中伪元素可能不被认为是元素的子元素?

另一种方法

无论如何,我有一些像这样的复选框和单选按钮的经验.我学到的一个非常酷的技巧是隐藏< input>关闭屏幕并设置关联的< label>用一些花哨的选择器技巧.此方法利用了点击< label>的事实.还会点击相关的< input>.

HTML

CSS

input[type="checkbox"] {

position:absolute;

left:-9999px;

top:-9999px;

}

input[type="checkbox"] + label {

visibility:visible;

content:"W";

display:block;

background:#0ab9bf;

width:20px;

line-height:20px;

text-align:center;

height:20px;

overflow:hidden;

}

input[type="checkbox"]:checked + label {

background:#F00;

}

改进方法

这个方法使用a b选择器,这意味着选择b紧跟在a之后.那么< label>必须在< input>之后.一种“更安全”的方法是使用通用兄弟选择器a~b将它们包装在容器和样式中.然后,样式将容忍< label>在不同的位置,只要他们仍然是兄弟姐妹.

It will still work!

兼容性

独立此方法与IE8及以下版本不兼容,因为它不支持:已选中.解决这个问题的通常方法是添加一个类.checked,但不幸的是IE8在更改类时也有一个rendering bug,而你需要更多hacky JavaScript.

var labels = document.querySelectorAll('label');

for (var i = 0; i < labels.length; i++) {

labels[i].onclick = handleClick;

}

function handleClick () {

var checkbox = document.getElementById(this.getAttribute('for'));

// do something with checkbox.checked

alert(checkbox.checked);

}

幸运的是,由于now tiny market share(<0.77%),你不需要支持低于8的任何东西.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值