前端开发-jQuery事件

Posted mike-liu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端开发-jQuery事件相关的知识,希望对你有一定的参考价值。

一、什么是事件

页面对不同访问者的响应叫做事件。

事件处理程序指的是当 html 中发生某些事件时所调用的方法。

实例:

  • 在元素上移动鼠标。
  • 选取单选按钮
  • 点击元素

在事件中经常使用术语"触发"(或"激发")例如: "当您按下按键时触发 keypress 事件"。

常见 DOM 事件

技术分享图片

 

二、jQuery事件方法语法

在jQuery中,大多数dom事件都有一个等效的jQuery方法

页面中指定一个点击事件:

$("p").click();

  下一步是定义什么时间触发事件。您可以通过一个事件函数实现:

$("p").click(function(){        
       
});

 

三、常用的 jQuery 事件方法

  • $(document).ready()

    $(document).ready() 方法允许我们在文档完全加载完后执行函数。

  • click()

    click() 方法是当按钮点击事件被触发时会调用一个函数。

    该函数在用户点击 HTML 元素时执行。

在下面的实例中,当点击事件在某个 <p> 元素上触发时,隐藏当前的 <p> 元素

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="js/jquery-3.3.1.js">

    </script>
    <script>
        $(document).ready(function () {
            $("p").click(function () {
                $(this).hide();

            });

        });
    </script>
</head>
<body>
<p>如果你点我,我就会消失。</p>
<p>点我消失!</p>
<p>点我也消失!</p>

</body>
</html>
  •   dblclick()

    当双击元素时,会发生 dblclick 事件。

    dblclick() 方法触发 dblclick 事件,或规定当发生 dblclick 事件时运行的函数:

  

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="../js/jquery-3.3.1.js">

    </script>
    <script>
        $(document).ready(function () {
            $("p").dblclick(function () {
                $(this).hide();

            });

        });
    </script>
</head>
<body>
<p>双击鼠标左键的,我就消失。</p>
<p>双击我消失!</p>
<p>双击我也消失!</p>

</body>
</html>

  

  • mouseenter()

    当鼠标指针穿过元素时,会发生 mouseenter 事件。

    mouseenter() 方法触发 mouseenter 事件,或规定当发生 mouseenter 事件时运行的函数:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="../js/jquery-3.3.1.js">

    </script>
    <script>
        $(document).ready(function () {
            $("#p1").mouseenter(function () {
                alert("你的鼠标移动到了id=p1的元素上!")

            })

        })
    </script>
</head>
<body>
<p id="p1">鼠标指针进入此处,会看到弹窗</p>

</body>
</html>

  

  • mouseleave()

    当鼠标指针离开元素时,会发生 mouseleave 事件。

          mouseleave()方法触发mouseleave事件,或规定当发生mouseleave事件时运行的函数:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="../js/jquery-3.3.1.js">

    </script>
    <script>
        $(document).ready(function () {
            $("#p1").mouseleave(function () {
                alert("再见,您的鼠标已经离开了该段落")

            })

        })
    </script>
</head>
<body>
    <p id="p1">这是一个段落。</p>

</body>
</html>

  

  • mousedown()

    当鼠标指针移动到元素上方,并按下鼠标按键时,会发生 mousedown 事件。

    mousedown() 方法触发 mousedown 事件,或规定当发生 mousedown 事件时运行的函数:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="../js/jquery-3.3.1.js">

    </script>
    <script>
        $(document).ready(function () {
            $("#p1").mousedown(function () {
                alert("鼠标在该段落上按下!")

            })

        })
    </script>
</head>
<body>
    <p id="p1">这是一个段落。</p>

</body>
</html>

  

  • mouseup()

    当在元素上松开鼠标按钮时,会发生 mouseup 事件。

    mouseup() 方法触发 mouseup 事件,或规定当发生 mouseup 事件时运行的函数:

  •  

    $(document).ready(function () {
                $("#p1").mouseup(function () {
                    alert("鼠标在该段落上按下!")
    
                })
    

      

  • hover()

    hover()方法用于模拟光标悬停事件。

    当鼠标移动到元素上时,会触发指定的第一个函数(mouseenter);当鼠标移出这个元素时,会触发指定的第二个函数(mouseleave)。

 $(document).ready(function () {
            $("#p1").hover(function () {
                alert("你进入了p1!");

            },
            function () {
                alert("拜拜!现在你离开了P1")

            });

        });
  •  focus()

    当元素获得焦点时,发生 focus 事件。

    当通过鼠标点击选中元素或通过 tab 键定位到元素时,该元素就会获得焦点。

    focus() 方法触发 focus 事件,或规定当发生 focus 事件时运行的函数:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="../js/jquery-3.3.1.js">

    </script>
    <script>
        $(document).ready(function () {
            $("input").focus(function () {
                $(this).css("background-color","#ccc");

            });
            $("input").blur(function () {
                $(this).css("background-color","#ffffff");

            });

        });
    </script>
</head>
<body>
    Name: <input type="text" name="fullname"><br>
Email: <input type="text" name="email">

</body>
</html>

  

比较keypress、keydown与keyup

  • keydown:在键盘上按下某键时发生,一直按着则会不断触发(opera浏览器除外),它返回的是键盘代码;
  • keypress:在键盘上按下一个按键,并产生一个字符时发生, 返回ASCII码。注意: shift、alt、ctrl等键按下并不会产生字符,所以监听无效,换句话说,只有按下能在屏幕上输出字符的按键时keypress事件才会触发。若一直按着某按键则会不断触发。
  • keyup:用户松开某一个按键时触发,与keydown相对,返回键盘代码.

以上是关于前端开发-jQuery事件的主要内容,如果未能解决你的问题,请参考以下文章

前端 ----jQuery的介绍

前端jQuery部分简单整理

前端开发 - jQuery

前端开发-jQuery事件

Python开发前端:jQuery

前端面试题之手写promise