内容过滤是一个在Web上常见的一个功能,特别是在电商网站,为了让用户过滤内容,仅显示符合自己的要求的内容。截个图来说,能更好的说明这样的功能,比如淘宝网:
如上图所示,用户想购买一件裙子,在整个产品列表中,显示的产品数量太多了。顾客不知道如何选择自己所需要的裙子。在顶部提供了一个分类,顾客选择需要的选项,产品中就会过滤掉不符合条件的产品。上图选择了”气质优雅“的裙子。当然还可以选择更多的条件。这里就不我多说了。
话说回来,以前实现这样一个效果都需要借助于JavaScript(或者基于jQuery插件)来做。比如CodyHouse的内容过滤示例。但对于一枚不懂JavaScript的同学来说(不懂不是理由),要实现类似的一个功能,的确是一件难事(偶有切身体会,欲哭无泪,谁叫当初没好好读书)。
所幸的事,如今天偶也可以不借助JavaScript来实现。也就是纯CSS来实现一个功能简单一点的内容过滤器,不是难事。这也是今天要与大家一起分享的。
先来看一个示例
先来看一个简单的示例,页面加载时,会有女装、男装和童装一起出现,当你做下面的操作时,有意想不到的效果:
当你点击”女装“按钮时,”男装“和”童装“都会被过滤掉
当你点击”男装“按钮时,”女装“和”童装“都会被过滤掉
当你点击”童装“按钮时,”女装“和”男装“都会被过滤掉
当然这个案例的功能没有淘宝网的那么NB,但好呆也是完成了一个类似内容过滤的功能。
实现原理
实现这个功能的原理其实并不太复杂,只是大家平时并未关注过。我归纳起来就是两个方面:
强大的选择器
实现这个功能,主要依赖于强大的CSS选择器中的通用兄弟选择器(E~F)和伪类选择器:checked。当某个单选按钮选中时,其他类的内容隐藏起来:
input[type="radio"]{
&[id="men"]:checked {
~ .women,
~ .children{
....
}
}
}
要通过上面样式来控制对应的.women和.children元素,必须保证元素与input元素是兄弟元素。这也是下面要说的第二个关键之处。
良好、匹配的结构
仅利用CSS制作这个功能,需要有严谨的结构,因为结构的错乱直接会影响到需要的效果。这也是其中不足之处。其中之一就是借助单选按钮”radio“和label匹配。为了外观的好看,不想显示,需要通过label的for属性来控制选中的”radio“。所以input的id值要和label的for值匹配。另外所有的input的name值一样,告诉浏览器,他们是属于一组的。如:
实现步骤
了解实现原理之后,要完成文章开头示例的效果就简单的多了。
HTML
HTML结构其实非常简单,只需要注意input和label的匹配以及将要过滤内容元素与其是兄弟元素。比如此例,内容元素主要有三类:男装.men、女装.women和童装.children。