JavaScript 事件案例

本文展示了两个JavaScript事件的应用案例:一是创建一个跟随鼠标的天使图片效果,通过监听mousemove事件来实时更新图片位置;二是模拟京东搜索功能,当用户按下s键时,光标自动定位到搜索框。此外,还介绍了京东快递单号查询的交互设计,通过监听input的keyup事件,实现实时显示放大版的快递单号并根据输入内容动态显示和隐藏放大框。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JavaScript 事件案例

1. 跟随鼠标的天使

<style>
        /* 跟随鼠标的天使 */
        img{
            position: absolute;
            top: 2px;

        }
</style>
<body>
    <!-- 跟随鼠标的天使 -->
    <img src="images/angel.gif" alt="">
    <script>
        var img=document.querySelector('img');
        document.addEventListener('mousemove',function(e){
            // mousemove 只要鼠标移动1px 就会触发事件
            // 核心原理:每次鼠标移动,我们都会获得最新的鼠标坐标,把这个x和y坐标作为图片的top和left值,就可以移动图片
            var x=e.pageX;
            var y=e.pageY;
            // 千万不要忘记不要给left 和 top添加px单位  图片大小是98X80
            img.style.left=x-50+'px';
            img.style.top=y-40+'px';
        })
    </script>
</body>

2. 模拟京东按键输入内容案例

// 按下s键,光标定位到搜索框
<body>
    <!-- 模拟京东按键输入内容案例 -->
    <input type="text">
    <script>
        // 核心思路:检测用户是否按下了s键,如果按下了s键,就把光标定位到搜索框里面
        // 使用键盘事件对象里面的keyCode,判断用户按下了s键
        // 搜索框获得焦点,使用js里面的focus方法
        var search=document.querySelector('input');
        document.addEventListener('keyup',function(e){
            if(e.keyCode===83){
                search.focus();
            }
        })
    </script>
</body>

3. 模拟京东快递单号查询

// 输入时会有放大框放大输入框内容
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        
        .search {
            position: relative;
            width: 178px;
            margin: 100px;
        }
        
        .con {
            display: none;
            position: absolute;
            top: -40px;
            width: 171px;
            border: 1px solid rgba(0, 0, 0, .2);
            box-shadow: 0 2px 4px rgba(0, 0, 0, .2);
            padding: 5px 0;
            font-size: 18px;
            line-height: 20px;
            color: #333;
        }
        
        .con::before {  /* 小三角 */
            content: '';
            width: 0;
            height: 0;
            position: absolute;
            top: 28px;
            left: 18px;
            border: 8px solid #000;
            border-style: solid dashed dashed;
            border-color: #fff transparent transparent;
        }
    </style>
<body>
    <div class="search">
        <div class="con">123</div>
        <input type="text" placeholder="请输入您的快递单号" class="jd">
    </div>
    <script>
        // 快递单号输入内容时, 上面的大号字体盒子(con)显示(这里面的字号更大)
        // 表单检测用户输入: 给表单添加键盘事件
        // 同时把快递单号里面的值(value)获取过来赋值给 con盒子(innerText)做为内容
        // 如果快递单号里面内容为空,则隐藏大号字体盒子(con)盒子
        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.innerText = this.value;
                }
            })
            // 当我们失去焦点,就隐藏这个con盒子
        jd_input.addEventListener('blur', function() {
                con.style.display = 'none';
            })
            // 当我们获得焦点,就显示这个con盒子
        jd_input.addEventListener('focus', function() {
            if (this.value !== '') {
                con.style.display = 'block';
            }
        })
    </script>
</body>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值