CSS--使用伪选择器制作箭头图标

 

 

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

 HTML

 1 <section class="main">
 2     <header class="title">图标变形过渡效果缩放式菜单</header>
 3     <section>
 4         <button>图标</button>
 5         <header>
 6             #300x100 淡色系
 7         </header>
 8         <div>
 9             <article>
10                 <img src="http://www.gbtags.com/gb/laitu/300x100" alt="" />
11             </article>
12         </div>
13     </section>
14     <section>
15         <button>图标</button>
16         <header>
17             #300x100 暗色系
18         </header>
19         <div>
20             <article>
21                 <img src="http://www.gbtags.com/gb/laitu/300x100/666666/ffffff" alt="" />
22             </article>
23         </div>
24     </section>
25 </section>

  

CSS

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

 

JavaScript

 1 $(function(){
 2     $('section section header').on('click', function () {
 3         var $this = $(this),
 4             parent_section = $this.parent(),
 5             closeDiv = $this.siblings('div'),
 6             contentheight = closeDiv.children('article').outerHeight();
 7         (closeDiv.height() === 0 ) ? closeDiv.height(contentheight) : closeDiv.height(0);   
 8         // 更改容器高度;
 9         $this.parents('section').first().toggleClass('open');
10         // 更改箭头样式;
11     });
12 });

 

 

转载于:https://www.cnblogs.com/yizihan/p/4561666.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/400219.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

datatables 响应式

https://datatables.net/extensions/responsive/

php 发送邮件

1.导入类文件mail&#xff0c;并创建对象 import(ORG.Com.Phpmailer); $mailnew PHPMailer(); 2.设置信息 $mail->IsSMTP();                     //设置使用SMTP服务器发送$mail->Host "smtp.126.com";             //设置1…

Linux多命令协作:管道及重定向

认识Linux中管道和重定向 如下图。 实践&#xff1a;重定向>的使用 转载于:https://www.cnblogs.com/mcgrady/p/7339770.html

【STC15库函数上手笔记】5、定时器

目录硬知识定时器初始化函数测试基本功能测试main.c中断服务函数实验现象模拟PWM信号main.c实验现象STC实验箱4 IAP15W4K58S4 Keil uVision V5.29.0.0 PK51 Prof.Developers Kit Version:9.60.0.0 硬知识 摘自《STC库函数使用参考》 定时器初始化函数 Timer_Inilize TIM_…

cdoj 1150 排名表 拓扑排序

排名表 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1150 Description 暑假前集训已经过了一半了&#xff0c;我们将会把当前排名公布出来。但是此刻秋实大哥却心急火燎&#xff0c;因为他不慎把排名删除了。一共有n个人参加排名…

c++ 连接两个字符串实现代码 实现类似strcat功能(转)

想实现strcat功能&#xff0c;直接网上找一个。 第一种&#xff1a; #include "stdafx.h" #include<iostream> using namespace std; int _tmain(int argc, _TCHAR* argv[]) { char s1[60]"kingbaby"; char *s2"hello"; int i0;int …

使用ajax完成python flask前端与后台数据的交互

https://blog.csdn.net/omodao1/article/details/83049960

Linux内存卡(SD卡、TF卡)作为Swap交换空间

目录平台&#xff1a;华硕 Thinker Edge R 瑞芯微 RK3399Pro 固件版本&#xff1a;Tinker_Edge_R-Debian-Stretch-V1.0.4-20200615 编译ORB-SLAM3时内存不足报错&#xff0c;专门买来一个32G的内存卡&#xff0c;设成swap试试。 插上内存卡&#xff0c;使用如下命令查看&#…

mysqldumper

介绍MySQL自身的mysqldump工具支持单线程工作&#xff0c;依次一个个导出多个表&#xff0c;没有一个并行的机&#xff0c;这就使得它无法迅速的备份数据。mydumper作为一个实用工具&#xff0c;能够良好支持多线程工作&#xff0c;可以并行的多线程的从表中读入数据并同时写到…

第二阶段冲刺进程6

今天是一个值得纪念的日子&#xff0c;为什么呢&#xff0c;因为我们的程序已经基本做出来啦~ 因为考虑到sqlite还是比较麻烦&#xff0c;主要是没有学过&#xff0c;很多东西可能很简单&#xff0c;但就是不会写&#xff0c;所以我们用了读取txt文件里的单词&#xff0c;相当于…

机器学习算法及应用领域相关的中国大牛

李航&#xff1a;http://research.microsoft.com/en-us/people/hangli/&#xff0c;是MSRA Web Search and Mining Group高级研究员和主管&#xff0c;主要研究领域是信息检索&#xff0c;自然语言处理和统计学习。近年来&#xff0c;主要与人合作使用机器学习方法对信息检索中…

python和flask中返回JSON数据

https://blog.csdn.net/matengbing/article/details/78653591

【STC15库函数上手笔记】6、ADC

目录硬知识ADC初始化函数ADC电源控制函数ADC查询转换函数测试main.c实验现象STC实验箱4 IAP15W4K58S4 Keil uVision V5.29.0.0 PK51 Prof.Developers Kit Version:9.60.0.0 硬知识 摘自《STC库函数使用参考》 ADC初始化函数 ADC_Inilize ADC_InitTypeDef的定义见于文件&q…

python3.x : 安装opencv

原文链接&#xff1a; http://blog.csdn.net/keith_bb/article/details/65447707?locationNum6&fps1 ———————————————————————————— 1.OpenCV下载 首先创建一个空的文件夹&#xff0c;进入文件夹执行如下命令,如我创建的文件夹是opencv-pytho…

NEWS - InstallShield 2015 正式发布

如果您需要为Windows应用程序创建安装&#xff0c;InstallShield便是您的最佳解决方案。在为桌面、服务器、云、Web和虚拟环境构建可靠的Windows Installer (MSI)和InstallScript安装程序时&#xff0c;InstallShield让开发团队能轻松地提高敏捷性、灵活性和协作性。 美国时间2…

【RK3399Pro学习笔记】十七、Debian安装ORB-SLAM3和单目demo的运行

目录安装OpenCV 3注意事项安装Glew安装Pangolin安装boost安装Eigen 3安装ORB_SLAM3试用平台&#xff1a;华硕 Thinker Edge R 瑞芯微 RK3399Pro 固件版本&#xff1a;Tinker_Edge_R-Debian-Stretch-V1.0.4-20200615 参考资料&#xff1a; 【入门必看】视觉惯性SLAM“灭霸”&am…

Flask设置返回json格式数据

https://blog.csdn.net/angus_17/article/details/80455838 from flask import Flask, jsonifyapp Flask(__name__)app.route(/) def root():t {a: 1,b: 2,c: [3, 4, 5]}return jsonify(t)if __name__ __main__:app.debug Trueapp.run()问题描述 在Flask中直接返回list或d…

C#多线程学习之:Monitor类

关于对C#多线程类Monitor的理解 1、对线程的理解 围绕着锁周围的线程可以分为以下三类&#xff1a; l 拥有锁的线程&#xff1a;只有一个 l 就绪队列&#xff1a;只有就绪队列里的线程才有机会在锁被释放时去获取锁。 l 等待队列&#xff1a;没有资格去获取锁。 2、Monitor.…

形参的一种特殊写法

形参的一种特殊写法 import java.lang.*; import javax.swing.*; import javax.swing.text.IconView;public class Xample_3 {public void Str (String...strings){for(int i0; i<strings.length;i){System.out.println(strings[i]);}}public void Int(int...is){int isall …

【0.96寸 OLED屏实现1500Fps的帧率】STM32 软件、硬件SPI、I2C驱动总结

目录SPI版OLED SPI 端口定义七针OLED引脚定义六针OLED引脚定义软件SPI硬件SPI启用DMA帧率测试I2C 版软件I2C硬件I2CDMASTM32F103VET6 STM32 Cube IDE SPI版 OLED SPI 端口定义 本节引自STM32驱动0.96寸OLED液晶屏(12864液晶屏) —— 小牧同学 两种屏幕的引脚数不一样&#x…