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结构,因为相邻兄弟选择器对于结构的依赖程度非常的强。也就是说结构修改之后,你的选择器和样式都要做一定的修改。

通篇下来,是不是觉得非常的简单。如果你感兴趣的话,可以借助这个案例的思路,通过”复选框“按钮来实现多项内容过滤的效果。也就是符合多个条件的内容显示,不符合的隐藏。试试呗,你一定行。

转载于:https://www.cnblogs.com/huangf714/p/5876174.html

web中用纯CSS实现筛选菜单相关推荐

  1. 兼容FF,IE的纯CSS下拉菜单

    代码简介:作者的CSS水平不错啊,值得我们学习,少了JS,就是好看多. 代码内容: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Trans ...

  2. html列表太多转为下滑菜单,利用CSS过渡属性Transition制作缓缓弹出的纯CSS下拉菜单...

    利用CSS过渡属性Transition制作缓缓弹出的纯CSS下拉菜单 以往文章里面讲了使用CSS的position属性定位结合display制作下拉弹出菜单,名为<纯CSS制作下拉导航菜单> ...

  3. 全兼容的纯CSS级联导航菜单源码

    参与测试的浏览器:IE6 / IE7 / IE8 / FF3 / OP9.6 / SF3 / Chrome2 操作系统:Windows 蓝色理想经典论坛首发,转载请注明出处 这次给项目做的级联菜单使用 ...

  4. 纯 CSS 的多级菜单

    无脚本,纯 CSS 实现,在非 IE 内核浏览器和 IE8+ 表现完美. <!DOCTYPE HTML> <html> <head><meta http-eq ...

  5. 纯CSS实现多级菜单,兼容IE6

    HTML <div id='nav'><div class='welcome'>欢迎您:xxx <a href='#'>[退出登录]</a></d ...

  6. 纯CSS菜单样式,及其Shadow DOM,Json接口 实现

    先声明,要看懂这篇博客要求你具备少量基础CSS知识, 当然如果你只是要用的话就随便了,不用了解任何知识 先放一张效果图         Part 1:纯CSS菜单样式 先放样式代码 1 <sty ...

  7. 兼容IE各版本的纯CSS二级下拉菜单

    这是一个标准的CSS下拉菜单制作教程,有针对目前流行的IE6/IE7/IE8不同版本的CSS代码,因此可以在IE之间完全兼容,不过其它的浏览器像火狐/GG浏览器之类的没有测试,如果兼容IE8的话,那么 ...

  8. 纯 CSS 中的简单响应式汉堡菜单

    欢迎阅读有关如何创建简单的响应式纯 CSS 汉堡菜单的教程.是的,互联网上有很多其他的汉堡菜单,但其中一些仍然需要使用 Javascript.所以这里是一个纯 CSS 驱动的菜单,而不是一行 Java ...

  9. 精致纯CSS打造绿色漂亮导航栏

    代码简介: 极精致的纯CSS实现的菜单,兼容性非常好,条例WEB标准,能用性好,用到有修饰图片,请根据代码地址自己下载. 代码内容: <!DOCTYPE html PUBLIC "-/ ...

最新文章

  1. pandas 第一行_Pandas进阶,从0到100你还差这篇文章!
  2. IPFS: BitSwap协议(数据块交换)
  3. 毕业论文 | 单相AC-DC变换电路(附源代码与电路设计图及器件清单)电子设计大赛
  4. 计算机视觉 | 计算机视觉相关算法及工具
  5. Java获取指定日期的月初和月末日子
  6. 阿里云——ECS——Linux服务器购买流程——超级细致
  7. 数据结构 练习21-trie的原理分析和应用
  8. 今天我开通了51cto的博客
  9. Spring Boot 自定义属性值
  10. Filecoin将启动第一轮全球社区开发者二次方投票资助计划和线上Hackathon
  11. 新媒体增长方法从哪里找?
  12. LA 4794 状态DP+子集枚举
  13. Virtualbox安装Windows7虚拟机
  14. 找回foxmail下的邮箱密码
  15. SSLv3 协议漏洞‘POODLE’修复与相关概念
  16. 《MATLAB 神经网络43个案例分析》:第25章 基于MIV的神经网络变量筛选----基于BP神经网络的变量筛选
  17. SQL数据库笛卡尔积、投影、选择、连接运算
  18. 支付宝原型设计-低保真Axure9支付宝界面设计
  19. ubuntu清理缓存
  20. 北京航空航天大学计算机系考研复试上机真题及答案---2014

热门文章

  1. 你不能忽视的HTML语言3
  2. R语言:绘制知识图谱
  3. mysql导出excel命令,在命令行导出MySQL数据到excel表
  4. excel python 形状_何使用Python操作Excel绘制柱形图
  5. 华为mate20 android,华为Mate20 Pro上手:安卓最强机会带来哪些体验惊喜?
  6. W7程序计算机面板介绍,win7系统隐藏任意程序运行界面的详细步骤
  7. linux系统下的oracle数据库,在Linux系统下安装Oracle数据库
  8. wordpress ajax 调用wpdb_莫名其妙的调用Roboto字体又莫名其妙的恢复的过程
  9. hihocoder1513 小Hi的烦恼
  10. Web应用中的缓存一致性问题