零基础学前端开发 色彩缤纷的Bottom Bar

15 篇文章 0 订阅
4 篇文章 0 订阅

零基础学前端开发  色彩缤纷的Bottom Bar

<!DOCTYPE html>

<html lang="en">


<head>

    <meta charset="UTF-8">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <meta http-equiv="X-UA-Compatible" content="ie=edge">

    <title>Material BottomBar</title>

    <style>

        @keyframes morewidth {

            from {

                padding: 0 12px;

            }

            to {

                padding: 0 18px;

            }

        }


        @keyframes active1 {

            to {

                background-color: green;

            }

        }


        @keyframes active2 {

            to {

                background-color: deepskyblue;

            }

        }


        @keyframes active3 {

            to {

                background-color: deeppink;

            }

        }


        @keyframes active4 {

            to {

                background-color: yellowgreen;

            }

        }


        @keyframes active5 {

            to {

                background-color: gray;

            }

        }


        html,

        body {

            width: 100%;

            height: 100%;

            margin: 0;

            padding: 0;

        }


        .bottom-bar {

            width: 375px;

            height: 56px;

            position: relative;

            margin: 0;

            padding: 0;

            list-style: none;

            display: flex;

            background-color: green;

        }


        .bottom-bar li {

            flex-grow: 1;

            padding: 0 12px;

            cursor: pointer;

        }


        .bottom-bar li:hover {

            animation: morewidth 0.2s forwards;

        }


        .bottom-bar li span {

            height: 100%;

            display: flex;

            flex-direction: column;

            justify-content: center;

            align-items: center;

        }


        .bottom-bar li span b {

            color: white;

            font-weight: lighter;

            font-size: 12px;

        }


        .bottom-bar li span b:nth-child(2) {

            width: 0;

            height: 0;

            overflow: hidden;

        }


        .bottom-bar li:hover span b:nth-child(2) {

            width: auto;

            height: auto;

        }


        .bottom-bar li span>b:first-child {

            width: 24px;

            height: 24px;

            display: inline-block;

        }

    </style>

</head>


<body>

    <ul class="bottom-bar">

        <li class="bar-item" data-key="page1"><span><b style="background-image:url(
)"></b><b>one</b></span></li>

        <li class="bar-item" data-key="page2"><span><b style="background-image:url(
)"></b><b>two</b></span></li>

        <li class="bar-item" data-key="page3"><span><b style="background-image:url(
)"></b><b>three</b></span></li>

        <li class="bar-item" data-key="page4"><span><b style="background-image:url(
)"></b><b>four</b></span></li>

        <li class="bar-item" data-key="page5"><span><b style="background-image:url(
)"></b><b>five</b></span></li>

    </ul>

    <script>

        var bar = document.querySelector('.bottom-bar');

        bar.addEventListener('mousemove', function (e) {

            e.path.forEach(p => {

                if (p.className == "bar-item") {

                    switch (p.dataset.key) {

                        case "page1":

                            bar.style.animation = "active1 0.3s forwards";

                            break;

                        case "page2":

                            bar.style.animation = "active2 0.3s forwards";

                            break;

                        case "page3":

                            bar.style.animation = "active3 0.3s forwards";

                            break;

                        case "page4":

                            bar.style.animation = "active4 0.3s forwards";

                            break;

                        case "page5":

                            bar.style.animation = "active5 0.3s forwards";

                            break;

                    }

                }

            })

        })

    </script>

</body>


</html>

​零基础学前端开发,大量公益学习资源,进裙web前端25群下载

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值