首页 > 技术文章 > H5前端技术文章 >

强大而好用的选择器!

更新时间:2019-03-29 | 阅读量(711)

![强大而好用的选择器:focus-within](https://upload-images.jianshu.io/upload_images/3165547-81f64bbc0a67100f.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) ## 伪类和伪元素 ## 在开发网页样式中,选择器必不可少,而且选择器也是在开发css中非常重要的内容,包括常用的类选择器,id选择,同时还有伪类,伪类选择器最大的特点就是冒号开头。平时也经常会有小伙伴问到,在使用的时候有伪类,也有伪元素,有些添加单冒号,有些添加双冒号,有没有什么区别? 在网上总结的比较多的一个特点就是,其实在使用的时候,无论是伪类还是伪元素都是可以用单冒号的。但是伪元素可以用双冒号,而伪类只能用单冒号。符合标准而言,单冒号(:)用于 CSS3 伪类,双冒号(::)用于 CSS3 伪元素。 ## :focus-within伪类 ## 上面简单讲解一下伪元素选择器和伪类选择器,本文的主角是一个新的伪类选择器::focus-within。 :focus-within选择器其实跟:focus是很相似的,但是也有很大的区别,:focus设置之后,是当前元素触发焦点状态后的样式。而:focus-within,通过名字可以猜到,它是当前元素或者后的元素获取焦点后的样式。 举个栗子: ```
``` ![:focus](https://upload-images.jianshu.io/upload_images/3165547-e7547057332524f0.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) ![:focus-within](https://upload-images.jianshu.io/upload_images/3165547-356a134286e85b9d.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) 第一种情况是input元素获取焦点的时候触发,让input自身设置outline的样式;第二种情况,当input获取焦点后,form设置outline的样式。 通过这一点我们可以制造出一些常用的交互样式,简化JavaScript的代码。 ### 兼容性 ### 虽然是新选择器,但是兼容性还是挺友好的。 ![:focus-within的兼容性](https://upload-images.jianshu.io/upload_images/3165547-bc3c8b48cae66c9f.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) ### :focus-within 的冒泡性 ### 这个属性有点类似 Javascript 的事件冒泡,从可获焦元素开始一直冒泡到根元素 html,都可以接收触发 :focus-within 事件,在上面的示例中就是如此。 那么它可以有哪些实际应用呢? ### 感知用户聚焦位置 ### 跟上面示例一样,当用户触发之后,向父级进行传递,我们可以指定用户的聚焦位置,利用这一点,可以设置增加用户体验的交互效果。 举个栗子: ```
``` 效果如下图所示: ![感知聚焦区域](https://upload-images.jianshu.io/upload_images/3165547-0f48ff9b77f52a53.gif?imageMogr2/auto-orient/strip) 运用上面思想,我们可以把效果做的更炫一点点,在某些场景制作一些增强用户体验的效果。 ![:focus-within炫酷效果](https://upload-images.jianshu.io/upload_images/3165547-14618991f9c27835.gif?imageMogr2/auto-orient/strip) 也可以实现掘金网登录动效切换,掘金网的登录有一个小彩蛋,最上面的熊猫在你输入帐号密码的时候会有不同的状态。 ![登录框交互效果](https://upload-images.jianshu.io/upload_images/3165547-a045c911947df481.gif?imageMogr2/auto-orient/strip) 以上两个效果,大家可以自行尝试进行书写。 本文主要是引出这一个伪元素,大家可以发挥自己的创意,开发出更炫酷的效果。
叩丁狼学员采访 叩丁狼学员采访
叩丁狼头条 叩丁狼头条
叩丁狼在线课程 叩丁狼在线课程