web中用纯CSS实现筛选菜单
web中用纯CSS实现筛选菜单
本文我们来用纯css实现像淘宝宝贝筛选菜单那样的效果,例子虽然没有淘宝那样强大,不过原理差不多,如果花点心思也可以实现和淘宝一样的。
内容过滤是一个在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匹配。为了外观的好看,不想显示<input type="radio">,需要通过label的for属性来控制选中的”radio“。所以input的id值要和label的for值匹配。另外所有的input的name值一样,告诉浏览器,他们是属于一组的。如:
<input type="radio" id="men" name="clothing"
/>
<label for="men">男装</label>
<input type="radio" id="women"
name="clothing"/>
<label for="women">女装</label>
<input type="radio" id="children"
name="clothing"/>
<label for="children">童装</label>
<input type="radio" id="reset"
name="clothing"/>
<label for="reset">重置</label>
实现步骤
了解实现原理之后,要完成文章开头示例的效果就简单的多了。
HTML
HTML结构其实非常简单,只需要注意input和label的匹配以及将要过滤内容元素与其是兄弟元素。比如此例,内容元素主要有三类:男装.men、女装.women和童装.children。
<div class="container">
<!-- 必须保证input和label匹配 -->
<input type="radio" id="men"
name="clothing " />
<label for="men">男装</label>
<input type="radio" id="women"
name="clothing "/>
<label for="women">女装</label>
<input type="radio" id="children"
name="clothing "/>
<label for="children">童装</label>
<input type="radio" id="reset"
name="clothing "/>
<label for="reset">重置</label>
<!-- 要被过滤的内容元素需要与input元素是兄弟元素 -->
<div class="tile men">
<img src=""
alt="">
</div>
<div class="tile women">
<img src=""
alt="">
</div>
<div class="tile children">
<img src=""
alt="">
</div>
<!-- 此处省略N个.men、.women和.children元素 -->
</div>
SCSS
明白原理,就简单多了,首先来看整体的代码:
body{
margin:0;
text-align:center;
font-family: Verdana;
background:#f5f5f5;
}
h1 {
text-align:center;
}
.container {
width:90%;
margin:0 auto;
}
input[type="radio"] {
display:none;
}
label {
width:23%;
float:left;
text-align:center;
background:#ffffff;
box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
color:#222222;
padding:0.5%;
margin:0.5%;
margin-bottom:30px;
cursor:pointer;
}
input[type="radio"]{
&[id="men"]:checked {
* label {
background:#6666ff;
}
~ .women,
~ .children {
width:0;
height:0;
padding:0;
margin:0;
opacity:0;
}
}
&[id="women"]:checked {
* label {
background:#ff4466;
}
~ .men,
~ .children {
width:0;
height:0;
padding:0;
margin:0;
opacity:0;
}
}
&[id="children"]:checked {
* label {
background:#66dd99;
}
~ .men,
~ .women {
width:0;
height:0;
padding:0;
margin:0;
opacity:0;
}
}
}
.tile {
width:23%;
float:left;
transition:all 1s;
margin:0.5%;
padding:0.5%;
background:#6666ff;
img {
width: 100%;
}
}
简单的解析一下这个样式代码。
为了页面好看,首先把<input>隐藏掉:
input[type="radio"] {
display:none;
}
我们通过label的for属性来控制radio有没有选中。美化一下label样式:
label {
width:23%;
float:left;
text-align:center;
background:#ffffff;
box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px
rgba(0,0,0,0.24);
color:#222222;
padding:0.5%;
margin:0.5%;
margin-bottom:30px;
cursor:pointer;
}
接下来样式代码也是最关键的一部分,当input选中之后label的样式:
input[type="radio"]{
&[id="men"]:checked {
+ label {
background:#6666ff;
}
}
...
}
上面的代码表示的是<input type="radio"
id="men">选择中:checked时,其相邻的label改变背景颜色。
根据前面的原理介绍,可以得知,当我们选择了”男装“,那么”女装“和”童装“就需要隐藏,在这里通过假像来隐藏,也就是input[type="radio"][id="men"]选中,其相通兄弟元素.women和.children隐藏掉:
input[type="radio"]{
&[id="men"]:checked {
...
~ .women,
~ .children {
width:0;
height:0;
padding:0;
margin:0;
opacity:0;
}
}
}
其他两个选项也是类似的,就不在做过多的阐述。
美化的样式,这里就不说了,大家都懂的。
通过这个过程下来,你就能看到前面DEMO展示的效果了。
总结
本文主要介绍了如何依赖于CSS的属性选择器、通用相邻兄弟选择器和伪类选择器来实现一个简单的内容过滤的功能。在整个实例当中,要把握的是严谨的HTML结构,因为相邻兄弟选择器对于结构的依赖程度非常的强。也就是说结构修改之后,你的选择器和样式都要做一定的修改。
通篇下来,是不是觉得非常的简单。如果你感兴趣的话,可以借助这个案例的思路,通过”复选框“按钮来实现多项内容过滤的效果。也就是符合多个条件的内容显示,不符合的隐藏。试试呗,你一定行。
web中用纯CSS实现筛选菜单的更多相关文章
- 支持多种浏览器的纯css下拉菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- CSS+JS下拉菜单和纯CSS下拉菜单
下拉菜单 (思路:先把二级定位到屏幕外,鼠标悬停重新定位回来:另一个就是ul浮动,li也浮动) 下拉菜单的一般思路就是把子导航嵌套在无序列表中,把列表定位到屏幕之外,当鼠标悬停在其父列表项上时,重新定 ...
- 纯CSS二级纵向菜单
纯CSS二级纵向菜单 <body> <div class="divda"> <div class="nav"> <ul ...
- 如何用纯 CSS 创作一个菜单反色填充特效
效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览.https://codepen.io/comehope/pen/qYMoPo 可交互视频教程 ...
- 前端每日实战:23# 视频演示如何用纯 CSS 创作一个菜单反色填充特效
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览.https://codepen.io/comehope/pen/qYMoPo 可交互视频教程 此视频是 ...
- 纯CSS弹出菜单(不支持IE6.0以下)
<!DOCTYPE html> <html lang="en" xmlns="http://www.w3.org/1999/xhtml"> ...
- 纯css下拉菜单的制作
通过观察下拉菜单的过程,发现有两种状态,一种是鼠标没有hover时,一种是鼠标hover时. 主菜单hover时,显示子菜单:主菜单没有hover时,不显示子菜单 <!DOCTYPE html& ...
- 23.1纯 CSS 创作一个菜单反色填充特效
交互效果地址:https://scrimba.com/c/cEwREJs6 HTML代码: <nav> <ul> <li><span>Home</ ...
- 23.纯 CSS 创作一个菜单反色填充特效
原文地址:https://segmentfault.com/a/1190000014876348 HTML代码: <nav> <ul> <li><span&g ...
随机推荐
- [Functional Programming Monad] Apply Stateful Computations To Functions (.ap, .liftA2)
When building our stateful computations, there will come a time when we’ll need to combine two or mo ...
- OpenCV和Matlab
OpenCV(Open Computer Vision)是现在流行的做计算机视觉和图像处理的工具库.Matlab一般用于快速实现算法和测试,用于研究理论,OpenCV适合开发实际的图像处理或视觉的应用 ...
- jquery操作select2控件
(一)select2常用的操作:添加.移除.获取选中的value()与text() (1)移除事件:$("#select_id").unbind("change" ...
- 基于Prometheus搭建SpringCloud全方位立体监控体系
前提 最近公司在联合运维做一套全方位监控的系统,应用集群的技术栈是SpringCloud体系.虽然本人没有参与具体基础架构的研发,但是从应用引入的包和一些资料的查阅大致推算出具体的实现方案,这里做一次 ...
- 数据库连接dbcp$c3p0
<?xml version="1.0" encoding="UTF-8"?> <c3p0-config> <!-- 这是默认配置信 ...
- 坑爹的Adprep32.exe
今天看书的时候,看到用ADSI设置Universal Group Membership Caching,就想到用.Net Framework来实现,找了半天,才找到System.directoryse ...
- 使用Nexus创建私服
原文链接:http://www.cnblogs.com/helong/articles/2254446.html 注意:nexus2.6.0版本以后不支持jdk6了,必须jdk1.7或以上. 参考:h ...
- 关于wcf,webservice,webapi或者其他服务或者接口有什么区别 WCF、WebAPI、WebService之间的区别 【转载】HTTP和SOAP完全就是两个不同的协议 WebService学习总结(一)——WebService的相关概念
wcf,webservice采用的是rpc协议,这个协议很复杂,所以每次要传递.要校验的内容也很复杂,别看我们用的很简单,但实际是frame帮我们做掉了rpc生成.解析的事情webapi遵循是rest ...
- EMQ配置“ClientId 认证”
EMQ配置“ClientId 认证” 基于 MQTT 客户端 ID 认证 clientId配置文件地址 /etc/emqttd/plugins/emq_auth_clientid.conf 内容如下: ...
- NOJ 1012 进制转换(十进制转换成随意进制)
题目: 进制转换 时间限制(普通/Java) : 1000 MS/ 3000 MS 执行内存限制 : 65536 KByte总提交 : 1819 測试通过 : ...