美文网首页程序员JavaScript
6.DOM:常用鼠标事件(client、page、screen)

6.DOM:常用鼠标事件(client、page、screen)

作者: 蔚完待旭 | 来源:发表于2020-06-17 12:25 被阅读0次

    1.1. 常用鼠标事件

    1.1.1 案例:禁止选中文字和禁止右键菜单

    <body>
        我是一段不愿意分享的文字
        <script>
            // 1. contextmenu 我们可以禁用右键菜单
            document.addEventListener('contextmenu', function(e) {
                    e.preventDefault();
            })
            // 2. 禁止选中文字 selectstart
            document.addEventListener('selectstart', function(e) {
                e.preventDefault();
            })
        </script>
    </body>
    

    1.1.2 鼠标事件对象

    1.1.3 获取鼠标在页面的坐标

        <script>
            // 鼠标事件对象 MouseEvent
            document.addEventListener('click', function(e) {
                // 1. client 鼠标在可视区的x和y坐标
                console.log(e.clientX);
                console.log(e.clientY);
                console.log('---------------------');
    
                // 2. page 鼠标在页面文档的x和y坐标
                console.log(e.pageX);
                console.log(e.pageY);
                console.log('---------------------');
    
                // 3. screen 鼠标在电脑屏幕的x和y坐标
                console.log(e.screenX);
                console.log(e.screenY);
    
            })
        </script>
    

    1.1.4 案例:跟随鼠标的天使

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

    1.2. 常用的键盘事件

    1.2.1 键盘事件

        <script>
            // 常用的键盘事件
            //1. keyup 按键弹起的时候触发 
            document.addEventListener('keyup', function() {
                console.log('我弹起了');
            })
    
            //3. keypress 按键按下的时候触发  不能识别功能键 比如 ctrl shift 左右箭头啊
            document.addEventListener('keypress', function() {
                    console.log('我按下了press');
            })
            //2. keydown 按键按下的时候触发  能识别功能键 比如 ctrl shift 左右箭头啊
            document.addEventListener('keydown', function() {
                    console.log('我按下了down');
            })
            // 4. 三个事件的执行顺序  keydown -- keypress -- keyup
        </script>
    

    1.2.2 键盘事件对象

    使用keyCode属性判断用户按下哪个键

        <script>
            // 键盘事件对象中的keyCode属性可以得到相应键的ASCII码值
            // 1. 我们的keyup 和keydown事件不区分字母大小写  a 和 A 得到的都是65
            // 2. 我们的keypress 事件 区分字母大小写  a  97 和 A 得到的是65
            document.addEventListener('keyup', function(e) {
                console.log('up:' + e.keyCode);
                // 我们可以利用keycode返回的ASCII码值来判断用户按下了那个键
                if (e.keyCode === 65) {
                    alert('您按下的a键');
                } else {
                    alert('您没有按下a键')
                }
            })
            document.addEventListener('keypress', function(e) {
                // console.log(e);
                console.log('press:' + e.keyCode);
            })
        </script>
    

    1.2.3 案例:模拟京东按键输入内容

    当我们按下 s 键, 光标就定位到搜索框(文本框获得焦点)。

    注意:触发获得焦点事件,可以使用 元素对象.focus()

        <input type="text">
        <script>
            // 获取输入框
            var search = document.querySelector('input');
            // 给document注册keyup事件
            document.addEventListener('keyup', function(e) {
                // 判断keyCode的值
                if (e.keyCode === 83) {
                    // 触发输入框的获得焦点事件
                    search.focus();
                }
            })
        </script>
    

    1.2.4 案例:模拟京东快递单号查询

    要求:当我们在文本框中输入内容时,文本框上面自动显示大字号的内容。

        <div class="search">
            <div class="con">123</div>
            <input type="text" placeholder="请输入您的快递单号" class="jd">
        </div>
        <script>
            // 获取要操作的元素
            var con = document.querySelector('.con');
            var jd_input = document.querySelector('.jd');
            // 给输入框注册keyup事件
            jd_input.addEventListener('keyup', function() {
                    // 判断输入框内容是否为空
                    if (this.value == '') {
                        // 为空,隐藏放大提示盒子
                        con.style.display = 'none';
                    } else {
                        // 不为空,显示放大提示盒子,设置盒子的内容
                        con.style.display = 'block';
                        con.innerText = this.value;
                    }
                })
            // 给输入框注册失去焦点事件,隐藏放大提示盒子
            jd_input.addEventListener('blur', function() {
                    con.style.display = 'none';
                })
            // 给输入框注册获得焦点事件
            jd_input.addEventListener('focus', function() {
                // 判断输入框内容是否为空
                if (this.value !== '') {
                    // 不为空则显示提示盒子
                    con.style.display = 'block';
                }
            })
        </script>
    

    相关文章

      网友评论

        本文标题:6.DOM:常用鼠标事件(client、page、screen)

        本文链接:https://www.haomeiwen.com/subject/dfeeohtx.html