【JS练习】快递查询框输入快递单号放大效果

效果

技术点

没什么技术点,注重思维

实现

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            outline: 0;
        }
        .search {
            position: relative;
            width: 200px;
            height: 80px;
            margin: 100px auto;
            /* background-color: pink; */
        }
        .con {
            display: none;
            position: absolute;
            top: 0;
            left: 0;
            /* width: 150px; */
            height: 30px;
            font-size: 24px;
            line-height: 30px;
            margin: 5px 25px;
            padding: 0 5px;
            border: 1px solid #ccc;
            border-radius: 2px;
            box-shadow: 0 0 8px 2px #ccc;
        }
        .con::after {
            position: absolute;
            content: '';
            top: 30px;
            left: 7px;
            width: 0px;
            height: 0px;
            border-style: solid;
            border-width: 10px;
            border-color:white transparent transparent transparent;
        }
        input {
            position: absolute;
            top: 45px;
            width: 150px;
            height: 20px;
            margin: 5px 25px;
        }
    </style>
</head>
<body>
    <div class="search">

        <div class="con"></div>
        <input type="text" placeholder="请输入快递单号" class="jd">
    </div>
    <script>
        // 绑定事件
        var con = document.querySelector('.con');
        var jd_input = document.querySelector('.jd');
        // 当键盘按下
        jd_input.addEventListener('keyup', function() {
            // 如果值为空,则隐藏
            if (this.value == '') {
                con.style.display = 'none';
            } else {
                // 否则显示
                con.style.display = 'block';
                con.innerHTML = this.value;
            }
        })
        // 当输入框失去焦点,隐藏
        jd_input.addEventListener('blur', function() {
            con.style.display = 'none';
        })
        // 当输入框得到焦点,显示
        jd_input.addEventListener('focus', function() {
            // 当得当焦点时进行判断是否为空
            if (this.value !== '') {
                con.style.display = 'block';
            }
        })
    </script>
</body>
</html>

 

本站部分文章资源来源于互联网,仅供学习交流,如若要商用,请购买正版!
若不听劝告,网友造成出现一切后果,与本站本人无关
本站有些资源未经测试,请注意网络安全,本站不对下载的资源造成的后果负责
免责声明
作者:昼白
转载请注明来源:https://www.zhoubaiwl.club/3262.htm
THE END
分享
二维码
打赏
< <上一篇
下一篇>>
文章目录
关闭
目 录