HTML5+CSS3小实例:全屏导航栏菜单

HTML5+CSS3实现全屏导航栏菜单,悬停在右上角的小图标,点击以圆形扩散的方式绽开全屏导航栏,这种方式的导航栏很吸睛,运用也越来越广,赶紧学起来呀!

效果:

源码:

<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="content-type" content="text/html; charset=utf-8">
    <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">

    <title>全屏导航栏菜单</title>
    <!-- 引入字体图标库 -->
    <link href="https://cdn.bootcdn.net/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
    <link rel="stylesheet" href="../css/9.css">
</head>

<body>
    <input type="checkbox" id="menu_btn">
    <label class="menu-btn" for="menu_btn">
        <i class="fa fa-bars" aria-hidden="true"></i>
    </label>
    <div class="con">
        <h1>全屏覆盖导航栏</h1>
        <h3>HTML + CSS</h3>
    </div>
    <div class="wrapper">
        <ul class="menu">
            <li><a href="#">首页</a></li>
            <li><a href="#">关于我们</a></li>
            <li><a href="#">服务</a></li>
            <li><a href="#">案例</a></li>
            <li><a href="#">用户反馈</a></li>
        </ul>
    </div>
</body>

</html>
*{
    /* 初始化 取消页面的内外边距 */
    margin: 0;
    padding: 0;
    /* 这个是告诉浏览器:你想要设置的边框和内边距的值是包含在总宽高内的 */
    box-sizing: border-box;
}
.con{
    /* 弹性布局 水平、垂直居中 */
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    /* 100%窗口高度 */
    height: 100vh;
    /* 行高 */
    line-height: 80px;
    font-size: 30px;
    /* 字间距 */
    letter-spacing: 15px;
}
.wrapper{
    /* 固定定位 窗口滚动也不会移动 */
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    /* 渐变背景 */
    background: linear-gradient(200deg,#ec77ab,#7873f5);
    /* 将元素剪切为一个圆形 【25px表示圆的半径】 【calc(100% - 45px) 45px表示圆心】 */
    clip-path: circle(25px at calc(100% - 45px) 45px);
    /* 过渡动画 */
    transition: all 0.3s ease-in-out;
}
.menu-btn{
    /* 绝对定位 */
    position: absolute;
    right: 20px;
    top: 20px;
    z-index: 2;
    text-align: center;
    line-height: 50px;
    height: 50px;
    width: 50px;
    border-radius: 50%;
    color: #fff;
    font-size: 20px;
    cursor: pointer;
    /* 渐变背景 */
    background: linear-gradient(200deg,#ec77ab,#7873f5);
    /* 过渡动画 */
    transition: all 0.3s ease;
}
#menu_btn{
    display: none;
}
#menu_btn:checked ~ .wrapper{
    /* 将元素剪切为一个圆形 75%表示圆的半径 */
    clip-path: circle(75%);
}
#menu_btn:checked ~ .menu-btn{
    color: #D576BA;
    background: #fff;
}
#menu_btn:checked ~ .menu-btn i::before{
    /* 复选框选中态改变图标 */
    content: "\f00d";
}
.wrapper ul{
    position: absolute;
    top:50%;
    left:50%;
    transform: translate(-50%,-50%);
    list-style: none;
    text-align: center;
}
.wrapper ul li{
    margin: 30px 0px;
}
.wrapper ul li a{
    color: #fff;
    text-decoration: none;
    font-size: 30px;
    font-weight: 500;
    padding: 5px 50px;
    position: relative;
    line-height: 50px;
    transition: all 0.3s ease;
}
.wrapper ul li a::after{
    content: "";
    position: absolute;
    width: 100%;
    height: 50px;
    background: #fff;
    left: 0px;
    z-index: -1;
    border-radius: 50px;
    transform: scaleY(0);
    transition: transform 0.3s ease;
}
.wrapper ul li a:hover::after{
    transform: scaleY(1);
}
.wrapper ul li a:hover{
    color:#D576BA;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容