// 使用Transform的属性,组合translate(位移)和rotate(旋转),将生成的小矩形组合成各种箭头样式;

HTML

 <section class="main">
<header class="title">图标变形过渡效果缩放式菜单</header>
<section>
<button>图标</button>
<header>
#300x100 淡色系
</header>
<div>
<article>
<img src="http://www.gbtags.com/gb/laitu/300x100" alt="" />
</article>
</div>
</section>
<section>
<button>图标</button>
<header>
#300x100 暗色系
</header>
<div>
<article>
<img src="http://www.gbtags.com/gb/laitu/300x100/666666/ffffff" alt="" />
</article>
</div>
</section>
</section>

CSS

 * { box-sizing:border-box;}
body { font-family: 'microsoft yahei',Arial,sans-serif; background: #aaa;}
section { position: relative; width:100%;}
section.main { position: absolute; top:10%; left:25%; width:50%; max-width:30em; min-width:15em; border-radius:5px; overflow: hidden;}
section.main > header { background: orange; color:#fff; line-height: 1.2em; text-align: center;}
section section:last-child { border:none;}
section > div { height:; overflow: hidden; transition:all .4s ease-in-out;}
article,header { padding:1em; line-height: 1em;}
header:not(.title) { width:100%; overflow: hidden; height:3em; background: #efefef; cursor:pointer; color:#888; white-space:nowrap; text-overflow: ellipsis; padding-right: 2.1em;}
header:not(.title):hover { background: #e8e8e8;}
article { line-height: 1.4em; background: rgba(255, 255, 255, .7);}
article img { width:100%; height:auto; border:2px solid white; border-radius: 3px;} /* 使用CSS3的伪选择器,生成关闭和向下两个图标按钮; */
/* 使用变形属性,组合位移和旋转,可将生成的小矩形组合成向下按钮,同样也可以组装成关闭按钮; */
section button { position: absolute; right:; margin:; padding:; height:3em; width:3em; outline:none; border:; background: none; text-indent: -9999px; pointer-events:none; cursor:pointer;}
section button:before,
section button:after { content:''; display: block; position: absolute; width:4px; height:12px; background: orange; border-radius: .3em; top:50%; left:50%; transition:all .3s ease-in-out;} /*向左箭头*/
/*section button:before { transform:translate(0%, -50%) rotate(45deg);}
section button:after { transform:translate(0%, 0%) rotate(-45deg);}*/ /*向右箭头*/
/*section button:before { transform:translate(0%, -50%) rotate(-45deg);}
section button:after { transform:translate(0%, 0%) rotate(45deg);}*/ /*向上箭头*/
/*section button:before { transform:translate(75%, -20%) rotate(-45deg);}
section button:after { transform:translate(-75%, -20%) rotate(45deg);}*/ /*向下箭头*/
section button:before { transform:translate(75%, 0%) rotate(45deg);}
section button:after { transform:translate(-75%, 0%) rotate(-45deg);} /* 点击之后需要变成"X"; */
section.open button:after,section.open button:before { background: red; height:14px; }
section.open button:before { transform:translate(-75%, -20%) rotate(45deg);}
section.open button:after { transform:translate(-75%, -20%) rotate(-45deg);}

JavaScript

 $(function(){
$('section section header').on('click', function () {
var $this = $(this),
parent_section = $this.parent(),
closeDiv = $this.siblings('div'),
contentheight = closeDiv.children('article').outerHeight();
(closeDiv.height() === 0 ) ? closeDiv.height(contentheight) : closeDiv.height(0);
// 更改容器高度;
$this.parents('section').first().toggleClass('open');
// 更改箭头样式;
});
});

CSS--使用伪选择器制作箭头图标的更多相关文章

  1. 用CSS伪元素制作箭头

    现在让我们开始制作箭头吧! 在开始前,你要知道如何用CSS去画一个三角形,如果还不清楚可以看看这里纯CSS画各种图形 我们用到两个CSS伪元素,before和after,它们属于行内元素,但可以用di ...

  2. css 利用border属性制作箭头 Using Borders to Make Pure CSS Arrows

    不再需要多余的图片 用border属性自然能创造箭头效果 学习地址:http://tech.patientslikeme.com/2010/11/09/using-borders-to-make-pu ...

  3. css 伪类选择器制作登录框表单

    使用伪类选择器 制作鼠标悬停时文本框出现橙色虚线边框 制作鼠标激活时出现背景颜色淡橙色 使用css制作文本框圆角矩形效果,制作文本框背景图片,及背景不重复效果 <!DOCTYPE html> ...

  4. CSS-用伪类制作小箭头(轮播图的左右切换btn)

    先上学习地址:http://www.htmleaf.com/Demo/201610234136.html 作者对轮播图左右按钮的处理方法一改往常,不是简单地用btn.prev+btn.next的图片代 ...

  5. CSS-用伪元素制作小箭头(轮播图的左右切换btn)

    先上学习地址:http://www.htmleaf.com/Demo/201610234136.html 作者对轮播图左右按钮的处理方法一改往常,不是简单地用btn.prev+btn.next的图片代 ...

  6. CSS制作简单图标

    CSS制作图标包括知识点如border-width.border-style.border-color.border-radius.对元素的定位拼接.旋转等结合起来. 图标效果如下(拖动滑块可缩放图标 ...

  7. css的伪元素 ::after ::before 和 图标字体的使用

    浅谈css的伪元素::after和::before   css中的::after和::before已经被大量地使用在我们日常开发中了,使用他们可以使我们的文档结构更加简洁.但是很多人对::after和 ...

  8. CSS之旅——第三站 强大的伪选择器

    说到伪选择器,真的让我体会到了CSS的无比强大,强大到自己貌似都不认识CSS了,有点C# 6.0中一些语法糖带给我们的震撼...首先 我们可以在VS里面提前预览一下. 可以看到,上面的伪类有很多很多, ...

  9. CSS的总结(选择器,伪类等...)

    关于组合选择器可参考:http://www.cnblogs.com/starof/p/4453458.html 主要内容 CSS概述 CSS和HTML结合的四种方式 CSS样式优先级和代码规范 CSS ...

随机推荐

  1. 你应该掌握的C++ RAII手法:Scopegaurd

    C++作为一门Native Langueages,在C++98/03时代,资源管理是个大问题.而内存管理又是其中最大的问题.申请的堆内存需要手动分配和释放,为了确保内存正确释放,一般原则是" ...

  2. 接之前的文章,VS2017中使用Spring.NET配置以及使用方法(framework4.6.1超详细)

    众所周知,Spring在java中是很常见的框架,Spring.Net虽然体积比较大,但是功能相对齐全,本文介绍在VS2017 .Net FrameWork 4.6.1环境下,如何快速使用Spring ...

  3. 背水一战 Windows 10 (71) - 控件(控件基类): UIElement - RenderTransform(2D变换), Clip(剪裁)

    [源码下载] 背水一战 Windows 10 (71) - 控件(控件基类): UIElement - RenderTransform(2D变换), Clip(剪裁) 作者:webabcd 介绍背水一 ...

  4. HDU1542 扫描线(矩形面积并)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  5. vsftpd安装配置以及常见问题解决

    vsftpd安装配置以及踩坑解决办法,Centos7 nginx已经配置成功了,但是使用http始终没办法访问到图片,那么你来对地方了(在文章末尾是原因) 配置nginx教程:http://blog. ...

  6. requsets模块的学习

    requests模块的学习 使用之前 pip install requests 发起get,post,请求获取响应 response = requests.get(url,headers) # 发起g ...

  7. C# 窗体间传值

    Form1: 父窗体, Form2: 子窗体. 1.父窗体接收子窗体的返回值: public partial class Form1: Form { private void btnOpen_Clic ...

  8. 如何开始DDD

    在开始DDD之前,你需要了解DDD的一些基础知识,聚合(AggregateRoot).实体(Entity).值对象(ValueObject),工厂(Factory),仓储(Repository)和领域 ...

  9. laravel框架的安装与配置

    正常安装: 1.composer.(https://getcomposer.org/Composer-Setup.exe) 安装之前要确保目录:wamp\bin\php\php5.4.3下的php.i ...

  10. Set "$USE_DEPRECATED_NDK=true" in gradle.properties to continue using the current NDK integration. 解决办法

    1.将 jni 文件夹名改为 cpp: 2.添加 CMakeLists.txt; 3.修改 build.gradle; externalNativeBuild { cmake { path " ...