码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • HTML+CSS实现按钮手风琴效果 | 青训营笔记


    HTML+CSS实现按钮手风琴效果 | 青训营笔记

      • 需求描述
      • HTML部分
      • CSS部分
      • 完整代码
      • 效果展示

    这是我参与「第四届青训营」笔记创作活动的的第7天。

    需求描述

    实现一排居中的五个图标,默认为圆形图案,鼠标移动到图标后,图标像手风琴一样展开,显示颜色和文字。

    HTML部分

    引入css库:

          <link rel="stylesheet" href="style.css">
          <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css"/>
    
    • 1
    • 2

    第一个是自定义的css,第二个是外部引用的组件库,提供fab fa-facebook-f等样式。

    定义两层盒子,大盒子内包含5个小盒子,小盒子装图标。

          <div class="wrapper">
             <div class="button">
                <div class="icon">
                   <i class="fab fa-facebook-f">i>
                div>
                <span>Facebookspan>
             div>
             <div class="button">
                <div class="icon">
                   <i class="fab fa-twitter">i>
                div>
                <span>Twitterspan>
             div>
             <div class="button">
                <div class="icon">
                   <i class="fab fa-instagram">i>
                div>
                <span>Instagramspan>
             div>
             <div class="button">
                <div class="icon">
                   <i class="fab fa-github">i>
                div>
                <span>Githubspan>
             div>
             <div class="button">
                <div class="icon">
                   <i class="fab fa-youtube">i>
                div>
                <span>YouTubespan>
             div>
          div>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32

    CSS部分

    首先导入google font的Poppins字体:

    @import url('https://fonts.googleapis.com/css?family=Poppins:400,500,600,700&display=swap');
    *{
      margin: 0;
      padding: 0;
      box-sizing: border-box;
      font-family: 'Poppins', sans-serif;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    盒子居中显示,背景采用渐变色:

    html,body{
      display: grid;
      height: 100%;
      width: 100%;
      place-items: center;
      background: linear-gradient(315deg, #ffffff 0%, #d7e1ec 74%);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    定义两个盒子wrapper和button,设置hover宽度变化:

    .wrapper .button{
      display: inline-block;
      height: 60px;
      width: 60px;
      float: left;
      margin: 0 5px;
      overflow: hidden;
      background: #fff;
      border-radius: 50px;
      cursor: pointer;
      box-shadow: 0px 10px 10px rgba(0,0,0,0.1);
      transition: all 0.3s ease-out;
    }
    .wrapper .button:hover{
      width: 200px;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    定义按钮颜色变化:

    .wrapper .button:nth-child(1):hover .icon{
      background: #4267B2;
    }
    .wrapper .button:nth-child(2):hover .icon{
      background: #1DA1F2;
    }
    .wrapper .button:nth-child(3):hover .icon{
      background: #E1306C;
    }
    .wrapper .button:nth-child(4):hover .icon{
      background: #333;
    }
    .wrapper .button:nth-child(5):hover .icon{
      background: #ff0000;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    完整代码

    Uestc-xiye/Buttons-with-Hover-Animation: HTML+CSS实现按钮手风琴效果 (github.com)

    效果展示

    在这里插入图片描述

    鼠标放在Github图标上后,按钮展开:

    在这里插入图片描述

  • 相关阅读:
    【Axure高保真原型】中继器版PDF阅读卡片
    【ML特征工程】第 4 章 :特征缩放的影响:从词袋到 Tf-Idf
    kr第三阶段(二)32 位汇编
    HDLbits exercises 12(SHIFT REGISTER全部题)
    环境配置--idea练习java实现一键运行
    计算机网络 八股
    【数据仓库设计基础(四)】数据仓库实施步骤
    计算机毕业设计Python+djang基于大数据的应届生求职系统(源码+系统+mysql数据库+Lw文档)
    MySQL 1、初识数据库
    如何现实笔记本已连接的密码
  • 原文地址:https://blog.csdn.net/ProgramNovice/article/details/126091454
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号