资讯专栏INFORMATION COLUMN

用 :focus-within 实现纯 CSS 下拉框组件

崔晓明 / 1679人阅读

摘要:借用的例子当点击表单中的文本框时需高亮整个表单元素。但是表单内部的文本框获得焦点并不代表表单元素本身有焦点,所以使用并不能生效,这时就可以使用当然这也是的其中一个典型用法。

:focus-within 伪类:当本节点或其子节点获得焦点时被激活。

借用 MDN 的例子

https://jsfiddle.net/d4w8h2ge/

当点击表单中的文本框时需高亮整个表单元素。但是表单内部的文本框获得焦点并不代表表单元素本身有焦点,所以使用 form:focus 并不能生效,这时就可以使用 :focus-within

当然这也是 :focus-within 的其中一个典型用法。

使用普通的绑定 click 事件的方式实现下拉框组件

回到正题,这是一个使用 JS 实现的下拉框:https://jsfiddle.net/omo6cov2/1/

为了实现这个下拉框,你通常(*)需要绑定两个 click 事件:一个在 a 标签上用于打开下拉框;一个在 body 上用于关闭下拉框。在 bodyclick 事件处理函数里,你得判断事件不能是来自下拉框内部的点击。你还得记得在移除下拉框(例如单页程序切换路由)时移除这个事件。

还有两个问题:

由于在 body 上绑定了事件,在下拉框关闭时也会触发,造成不必要的开销。

如果页面被嵌在 iframe 内,点击 iframe 外部元素不会触发 iframe 内部的 click 事件,所以无法通过点击 iframe 外部关闭下拉框。

使用 :focus-within 实现下拉框组件

这是一个使用 :focus-within 实现下拉框组件:https://jsfiddle.net/2vnn7fa4/1/

原理:点击链接时,a 元素获得焦点,激活了父元素的 :focus-within

除了把 .dropdown:not(.open) 改为 .dropdown:not(:focus-within) 外,还有一个要点:ul 标签本身(及其父元素们都)不能获得焦点,所以点击下拉框内部时默认会把整个文档的焦点清除。解决方法很简单:给 ul 标签添加 tabindex 属性即可。

另外:Chrome 的 devtool 里有一项 Force state -> :focus-within,调样式时不要忘了选

浏览器支持率,edge 需要加把劲了

(*):当然如果你非要把 a 元素上的 click 事件放入 document 的 click 事件里处理我也没意见。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/113308.html

相关文章

  • :focus-within 实现 CSS 下拉组件

    摘要:借用的例子当点击表单中的文本框时需高亮整个表单元素。但是表单内部的文本框获得焦点并不代表表单元素本身有焦点,所以使用并不能生效,这时就可以使用当然这也是的其中一个典型用法。 :focus-within 伪类:当本节点或其子节点获得焦点时被激活。 借用 MDN 的例子 https://jsfiddle.net/d4w8h2ge/ 当点击表单中的文本框时需高亮整个表单元素。但是表单内部的文...

    focusj 评论0 收藏0
  • FE.CSS-Sultana后记:css也能写col,select,datepicker,caro

    摘要:接着只要在中使用就能搞定自适应。代码如下标题标题标题标题标题在上述点功能中,可以用变量解决,比如实现了宽度,高度圆点大小直径的控件。 未完待续 背景 如今css3越来越发达,focus-within等属性也已经开始在Chrome得到支持。如果有出色的css功底,一点点ps技能,你也能用css3配合原生html标签写出优秀的框架。通过对css3的实践,我发现自定义原生控件并不是什么难事,...

    BigTomato 评论0 收藏0
  • FE.CSS-Sultana后记:css也能写col,select,datepicker,caro

    摘要:接着只要在中使用就能搞定自适应。代码如下标题标题标题标题标题在上述点功能中,可以用变量解决,比如实现了宽度,高度圆点大小直径的控件。 未完待续 背景 如今css3越来越发达,focus-within等属性也已经开始在Chrome得到支持。如果有出色的css功底,一点点ps技能,你也能用css3配合原生html标签写出优秀的框架。通过对css3的实践,我发现自定义原生控件并不是什么难事,...

    Lsnsh 评论0 收藏0
  • FE.CSS-Sultana后记:css也能写col,select,datepicker,caro

    摘要:接着只要在中使用就能搞定自适应。代码如下标题标题标题标题标题在上述点功能中,可以用变量解决,比如实现了宽度,高度圆点大小直径的控件。 未完待续 背景 如今css3越来越发达,focus-within等属性也已经开始在Chrome得到支持。如果有出色的css功底,一点点ps技能,你也能用css3配合原生html标签写出优秀的框架。通过对css3的实践,我发现自定义原生控件并不是什么难事,...

    lanffy 评论0 收藏0
  • FE.CSS-Sultana后记:css也能写col,select,datepicker,caro

    摘要:接着只要在中使用就能搞定自适应。代码如下标题标题标题标题标题在上述点功能中,可以用变量解决,比如实现了宽度,高度圆点大小直径的控件。 未完待续 背景 如今css3越来越发达,focus-within等属性也已经开始在Chrome得到支持。如果有出色的css功底,一点点ps技能,你也能用css3配合原生html标签写出优秀的框架。通过对css3的实践,我发现自定义原生控件并不是什么难事,...

    张金宝 评论0 收藏0

发表评论

0条评论

崔晓明

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<