好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

html5教程-CSS :focus-within伪类选择器及纯CSS下拉等应用举例

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

一、了解 CSS :focus-w IT hin伪 类选择器

CSS :focus-within 伪类 选择器和IE8就 开始 支持的 :focus 可以说是近亲,区别在于 :focus 表示当前元素处于focus状态时候干嘛干嘛,而 :focus-within 表示当前元素 或者 当前元素的子元素处于focus状态时候干嘛干嘛。

举个例子:

form:focus {   outline: solid; }

表示仅仅当 <form> 处于focus状态时候, <form> 元素 outline 出现。

form:focus-within {   outline: solid; }

表示 <form> 元素自身,或者 <form> 内部的子元素处于focus状态时候, <form> 元素 outline 出现。换句话说,子元素 focus ,可以让任意父级元素样式发生变化。

这个新特性的支持,未来势必会带来更加丰富的交互形式,以及特定场景 简化 我们实现。

@H_ 304 _43@兼容性

兼容性如下截图:

还是挺喜人的。

二、CSS :focus-within伪类选择器实际应用举例

1. 表单输入勿扰模式

当我们表单输入,选择或者进行交互时候,页面上表单以为其他内容全部都不可见。

CSS代码如下:

form {     outline: 2000px solid hsla(0,0%,100%,0);     transition: outline .2s;     position: relative;     z -i ndex: 1; } form:focus-within {     outline: 2000px solid hsla(0,0%,100%,1); }

效果如下 截屏 gif:

大屏浏览器体验更有感觉,您可以狠狠的点击这里::focus-within伪类选择器与表单输入勿扰模式demo

本案例是真实的勿扰模式效果可以放心大胆在实际项目中使用,因为这是一个体验增强的交互,就算浏览器不支持,对原本功能也不会有任何影响。

2. 带计数 文本域 的focus高亮

对于带计数的组件化的多行文本域,计数的数值通常是设计在文本域的 右下角 ,这样能够适应各种复杂的场景。如下截图:

然而这种设计对我们的布局实现带来的挑战。

我们通常想到的方法是,计数元素浮在下面的 textarea 元素上。然而这种时间存在有致命的不足,那就是输入框的内容有可能和我们的计数重叠,以及出现的滚动条和技 术 文本重叠,如下截图所示:

您可以狠狠地点击这里:带计数文本域自身:focus高亮重叠问题demo

因此,我们通常做法就是:边框使用父级 < div > 元素模拟,文本域元素和技术元素上下依次排列(非重叠),文本域原本的边框去除。

假设 HTML 如下:

<div class="textarea-x">     <textarea></textarea>     <label class="textarea-count">0/250</label> </div>

则核心CSS这样:

  /* 父级div元素模拟边框 */  .textarea-x {     border: 1px solid  # d0d0d5;     border-radius: 4px;     background-color: #fff; }  /* 文本域原本的边框去除 */  .textarea-x > textarea {     border: 0;     background: none; }

然而上面的实现有个非常严重的不足,那就是 <textarea> 元素 :focus 时候,边框无法高亮,因为CSS中没有父选择器!

因此,实际开发的时候,我们会使用相邻兄弟选择器,以及新建一个兄弟元素来模拟边框。

HT ML 结构如下:

<div class="textarea-x">     <textarea></textarea>     <div class="textarea"></div>     <label class="textarea-count">0/250</label> </div>

原理如下图示意:

对应的核心CSS代码如下:

.textarea-x {     position: relative;     z-index: 0; } .textarea-x > textarea {     border: 0;     background: none;     outline: 0;     re Size:  none;     position: relative; } .textarea-x > .textarea {     position: absolute;     border: 1px solid #d0d0d5;     border-radius: 4px;     background-color: #fff;     top: 0; bottom: 0; left: 0; right: 0;       z-index: -1; } .textarea-x > :focus + .textarea {     border-color: #00a5e0;     }

由于 .textarea 元素和原生的 <textarea> 元素是相邻兄弟关系,因此我们可以借助相邻兄弟选择器,让 <textarea> 元素focus时候后面用来模拟边框的 .textarea 元素高亮。也就是这么一段CSS代码:

.textarea-x > :focus + .textarea {     border-color: #00a5e0;     }

这种实现兼容IE7+浏览器。下图为实现后的效果截图:

当然涉及到具体代码,还是有很多 细节 需要注意的,您可以狠狠地点击这里: 利用 相邻兄弟选择器模拟带计数文本域:focus效果demo

但是,现在有了CSS :focus-within 伪类选择器,我们的事情就 简单 多了。

还是开始提到的父级 <div> 元素模拟的做法,然后,配合这么一句CSS就可以了:

.textarea-x:focus-within {     border-color: #00a5e0;     }

就是这么简单。

您可以狠狠地点击这里::focus-within伪类与带计数文本域高亮demo

focus时候效果如下截图:

三、:focus-within更多思路、更棒案例和结束语

:focus-within 伪类原本设计的作用是原生表单元素 focus 时候,祖先 <form> 元素可以也有状态变化。

但是在我看来, :focus-within 功能之强悍,远远不是仅仅和祖先 <form> 元素玩过家家这么简单。

理论上,只要页面上任意一个元素 focus ,通过 :focus-within 就能对页面上任意的元素进行样式控制。

例如:

html:focus-within xxx {      /*xxx跑得了吗?跑不了*/  }

我想到的有:

相邻选择器,加号,或者弯弯都只能选择后面的元素,但是,有了 :focus-within ,我们就可以对前面元素进行控制,虽然只能在 :focus 行为场景下。例如请重复输入密码时候,让上面的输入密码框也高亮。 基于纯CSS和focus行为实现下拉列表的交互成为了可能。只要把按钮和下拉元素放在一个容器中,就可以了。

您可以狠狠地点击这里::focus-within伪类与纯CSS下拉列表demo

点击“我的消息”,就会出现下拉列表;此时点击下拉列表里面的条目,下拉元素也一直显示(因为列表是可focus的 <a> 元素)。只有点击页面空白元素或其他位置,下拉列表才会隐藏。完全符合实际项目开发的下拉列表交互需求。

交互效果如下GIF截屏所示:

核心代码如下:

<div class="det ai ls">     <a  hr ef="javascript:" class="summary">我的消息</a>      <div class="box">         <a href="javascript:">我的回答<sup>12</sup></a>         <a href="javascript:">我的私信</a>         <a href="javascript:">未评价订单<sup>2</sup></a>         <a href="javascript:">我的关注</a>     </div> </div>
.box {     dis play : none; } .details:focus-within .summary {     background-color: #fff; } .details:focus-within .box {     display: block; }

抛砖引玉,集思广益。

补充于2018-06-27
IE Edge 目前最新版还没支持 :focus-within ,而且,测试 表明 ,当IE支持选择器和 :focus-within 一起使用的时候,会自动忽略整条语句,例如:

 /* IE浏览器忽略所有伪类,CSS语句无效 */  .ex am ple:hover, .example:active, .example:focus-within {     color:  red ; }

需要这样书写:

 /* IE浏览器可识别 */  .example:hover, .example:active {     color: red; }  /* IE不可识别 */  .example:focus-within {     color: red; }

这样现象也会我们区分IE浏览器和Ch rom e/Firefox提供了思路,例如,我们希望某一个元素IE浏览器下是 红色 ,其他浏览器下是蓝色,可以这样:

. br owser {     color: red; } .browser, .xxxx:focus-within {     color: blue; }

感谢阅读,欢迎交流!

(本篇完)

觉得 可用,就经常来吧! 欢迎评论哦!  html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-CSS :focus-within伪类选择器及纯CSS下拉等应用举例 全部内容,希望文章能够帮你解决 html5教程-CSS :focus-within伪类选择器及纯CSS下拉等应用举例 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-CSS :focus-within伪类选择器及纯CSS下拉等应用举例的详细内容...

  阅读:19次