前端 - 谁来解释下这两个 CSS selector 区别
问题描述
错误代码:
input { padding: 4px 0; // https://css-tricks.com/almanac/selectors/p/placeholder-shown/ &:focus:not(:placeholder-shown) + .input__clear, &.input--filled:focus + .input__clear { opacity: 1; }}
正确代码:
input { padding: 4px 0; // https://css-tricks.com/almanac/selectors/p/placeholder-shown/ &:focus:not(:placeholder-shown) + .input__clear { opacity: 1; } /* !!! 不能和上面的合并成一行,会导致下面的选择器无法匹配 */ &.input--filled:focus + .input__clear { opacity: 1; }}
demo 见https://jsfiddle.net/mLz7rajf/3/https://jsfiddle.net/mLz7rajf/5/正确情况应该是在不支持:placeholder-shown的浏览器(比如Firefox, 或者将placeholder-shown,随便改成一个无法识别的伪类),输入内容后显示 Clear
问题解答
回答1:貌似是浏览器bug
相关文章:
1. docker - 各位电脑上有多少个容器啊?容器一多,自己都搞混了,咋办呢?2. dockerfile - 为什么docker容器启动不了?3. docker gitlab 如何git clone?4. golang - 用IDE看docker源码时的小问题5. javascript - 修改表单多选项时和后台同事配合的问题。6. javascript - weex和node,js到底是怎样一个关系呢?7. nignx - docker内nginx 80端口被占用8. 我在centos容器里安装docker,也就是在容器里安装容器,报错了?9. docker安装后出现Cannot connect to the Docker daemon.10. 求大神指点js修改margintop导致无限下滑的问题

网公网安备