纯css折叠区域-基于checkbox
Accordion
Accordion即可折叠区域,和<details>标签类似,不过更灵活些。折叠区域往常多用JavaScript实现,这里就纯粹用CSS,就想法上也是异途同归。
折叠区域重在折叠两字,既然要折叠,必然要有能记录下当前折叠状态的元素存在,思来想去<input type="checkbox">恰好就是这样的元素,正好两个值,并且还可以互相切换,可以符合要求。如此说来,既然有了input,也能很自然地想到<label>了,label可以根据for来指向特定的input元素从而无需亲自点击它就可以修改它的状态,之后根据其状态checked来标志需要显示折叠区域,否则隐藏折叠区域。
实现的方法也不难,先设置.according-body的max-height为0,然后在checkbox为checked的状态下设置其max-height为一个足够大的值就好,如下:
.accordion-body{
padding-left: $unit-2;
margin-bottom: $layout-spacing;
max-height:;
overflow: hidden;
transition: max-height 0.25s;
}
input:checked ~,
&[open]{
& .accordion-body{
max-height: 100rem;
}
}
注意到这里指定的是max-height而非height,因为我们实际上并不知道折叠区域的高度,既然不知道高度,为何还需要特别指定一个max-height便是一个小技巧了。仔细再看一下.according-body的transition属性,它是可以根据max-height来实现过渡效果的,这样便实现了简单的动画,虽然看上去折叠的内容不能高于100rem是一个bug,但实际上很少会遇到需要折叠这么一大块区域的情况,因此并非什么大问题。
Accordion的大体结构这样便可以了,另外就是一些辅助性的效果,比方说折叠动作的时候显示区域旁边的小图标可以转一下之类的,利用transform便可以很轻易做到:
input:checked ~,
&[open]{
& .accordion-header{
.icon{
transform: rotate(90deg)
}
}
}
.accordion-header{
cursor: pointer;
display: block;
padding: $unit-1 $unit-2;
.icon{
transition: transform 0.25s;
}
}
如此一来Accordion也就完成了,不过考虑也可以在details标签中添加该类,所以需要将summary标签自带的小标志取消掉,如下:
summary.accordion-header{
&::-webkit-details-marker{
display: none !important;
}
}
Accordion的使用便只需要添加相应的类和input就好,如下:
<div class="accordion">
<input type="checkbox" id="ac-exp0" hidden>
<label for="ac-exp0" class="accordion-header">
<div class="icon icon-menu"></div>古都</label>
<div class="accordion-body">
<p>
...
</p>
</div>
</div>
纯css折叠区域-基于checkbox的更多相关文章
- ZH奶酪:纯CSS自定义Html中Checkbox复选框样式
原文链接:http://www.lrxin.com/archives-683.html 首先看下效果: 点击演示地址查看实例. 首先,需要添加一段CSS隐藏所有的Checkbox复选框,之后我们会改变 ...
- 用纯CSS美化radio和checkbox
Radio和checkbox需要美化吗?答案是必须的,因为设计风格一直都会变化,原生的样式百年不变肯定满足不了需求. 先看看纯CSS美化过后的radio和checkbox效果:查看. 项目地址:mag ...
- 纯css用图片代替checkbox和radio,无js实现方法
html <ul id="is_offical_post_links"> <li> <label> <input type="c ...
- 自定义常用input表单元素一:纯css 实现自定义checkbox复选框
最下面那个是之前写的 今天在做项目的时候发现,之前写的貌似还是有点多,起码增加的span标签可以去掉,这样保持和原生相同的结构最好的,仅仅是样式上的变化.今天把项目中的这个给更新上来.下面就直接还是 ...
- 转 纯CSS设置Checkbox复选框控件的样式
Checkbox复选框是一个可能每一个网站都在使用的HTML元素,但大多数人并不给它们设置样式,所以在绝大多数网站它们看起来是一样的.为什么不把你的网站中的Checkbox设置一个与众不同的样式,甚至 ...
- 使用checkbox实现纯CSS下拉框
在这个例子中,我们会看到一个纯CSS制作的下拉框.主要是要用到了HTML元素的checkbox 和CSS3选择器,并没有用到JavaScript.例子如下: Click to Expand Link ...
- 【转】纯CSS设置Checkbox复选框控件的样式
Checkbox复选框是一个可能每一个网站都在使用的HTML元素,但大多数人并不给它们设置样式,所以在绝大多数网站它们看起来是一样的.为什么不把你的网站中的Checkbox设置一个与众不同的样式,甚至 ...
- 纯CSS设置Checkbox复选框控件的样式
Checkbox复选框是一个可能每一个网站都在使用的HTML元素,但大多数人并不给它们设置样式,所以在绝大多数网站它们看起来是一样的.为什么不把你的网站中的Checkbox设置一个与众不同的样式,甚至 ...
- 基于flexbox纯css框架的解析
学CSS很好的一个方法大概是先用纯CSS来实现一个自己的框架,然后便可以在之后的使用中对一开始可能很粗糙的框架做细致的优化与改进,删除些冗余,添加些功能之类的. 当然,为了避免一开始写框架时候的时候手 ...
随机推荐
- MySQL 各类数据文件介绍
数据文件 在MySQL中每一个数据库都会在定义好(或者默认)的数据目录下存在一个以数据库名字命名的文件夹,用来存放该数据库中各种表数据文件. 不同的MySQL存储引擎有各自不同的数据文件,存放位置也有 ...
- 【Quartz】持久化到数据库【五】
前言 我们做到这里已经对Quartz定时器组件已经是学会了基本的使用了.但是我们有没有想过任务开启之后万一断掉了,当机了我们怎么办,你是否还想继续执行原先的任务.我们普通的创建是把任务放在内存中存 ...
- SSM-SpringMVC-19:SpringMVC中请求和响应的乱码解决
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 配置一道拦截器即可解决乱码 配置方式如下: 在web.xml中: <!--过滤器处理乱码--> ...
- SSM-MyBatis-04:Mybatis中使用properties整合jdbc.properties
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------properties整合jdbc.properties首先准备好jdbc.properties,里面的key值写 ...
- PHP生成腾讯云COS请求签名
目标 使用 PHP 创建 COS 接口所需要的请求签名 步骤 按照官方示例(也许是我笨,我怎么读都觉得官方文档结构费劲,示例细节互相不挨着,容易引起歧义),请求签名应用在需要身份校验的场景,即非公有读 ...
- Java VisualVM无法检测到本地java程序 的 解决办法
win10系统下启动jvisualvm应用,报"VisualVM无法检测到本地java程序"的错误!在网上查了一些方法, 大概原因有2种: 1.操作系统的临时文件目录所在的磁盘格式 ...
- 『个人の笔记』百度ife
✄--------------------------------------------task1分割线--------------------------------------------✄ 百 ...
- 关于基线baseline及与inline-block、vertical-aline等属性的关系(完善中.......)
1. 基本含义 基线(base line):而是英文字母x的下端沿,是a,c,z,x等字母的底边线,并不是汉字文字的下端沿,.下图的红色线即为基线.凡是涉及到垂直方向的排版或者对齐的,都离不开最最基本 ...
- 跟我学ASP.NET MVC之八:SportsStrore移动设备
摘要: 现在的web程序开发避免不了智能手机和平板电脑上的使用,如果你希望发布你的应用程序给更广大客户使用的话,你将要拥抱可移动web浏览器的世界.向移动设备用户发布一个好的使用体验是很困难的-比只是 ...
- document_index_data.go
package types type DocumentIndexData struct { // 文档全文(必须是UTF-8格式),用于生成待索引的关键词 Content string ...