jQuery事件

一、事件注册

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

<script>
        $(function() {
            //单个事件注册
            // $('div').click(function() {
            //     $(this).css('background', 'purple');
            // });
            // $('div').mouseenter(function() {
            //     $(this).css('background', 'skyblue');
            // });
            //2.事件处理on
            // $('div').on({
            //     mouseenter: function() {
            //         $(this).css('background', 'skyblue');
            //     },
            //     click: function() {
            //         $(this).css('background', 'purple');
            //     },
            //     mouseleave: function() {
            //         $(this).css('background', 'blue');
            //     }
            // });
            $('div').on('mouseenter mouseleave', function() {
                $(this).toggleClass('current');
            })
        })
    </script>

二、事件处理

2.1事件绑定

在这里插入图片描述
在这里插入图片描述

 // (2) on可以实现事件委托(委派)
            // $("ul li").click();
            $("ul").on("click", "li", function() {
                alert(11);
            });
            // click 是绑定在ul 身上的,但是 触发的对象是 ul 里面的小li
            // (3) on可以给未来动态创建的元素绑定事件
            // $("ol li").click(function() {
            //     alert(11);
            // })
            $("ol").on("click", "li", function() {
                alert(11);
            })
            var li = $("<li>我是后来创建的</li>");
            $("ol").append(li);
        })
    </script>

2.2事件处理off()解绑事件

在这里插入图片描述
只会触发一次点击事件 one()

$("p").one("click", function() {
                alert(11);
            })
<script>
        $(function() {
            $("div").on({
                click: function() {
                    console.log("我点击了");
                },
                mouseover: function() {
                    console.log('我鼠标经过了');
                }
            });
            $("ul").on("click", "li", function() {
                alert(11);
            });
            // 1. 事件解绑 off 
            // $("div").off();  // 这个是解除了div身上的所有事件
            $("div").off("click"); // 这个是解除了div身上的点击事件
            $("ul").off("click", "li");
            // 2. one() 但是它只能触发事件一次
            $("p").one("click", function() {
                alert(11);
            })
        })
    </script>

2.3自动触发事件trigger()

在这里插入图片描述
在这里插入图片描述

 <script>
        $(function() {
            // $('div').click(function() {

            // })
            $('div').on('click', function() {
                alert(11);

            });
            //1.元素.事件
            // $('div').click();
            //2.元素.trigger(‘事件’)
            // $('div').trigger('click');
            //3.元素.triggerHandler('事件')  不会触发元素的默认行为
            $('div').triggerHandler('click');
            $('input').on('focus', function() {
                $(this).val('你好吗');
            });
            $('input').triggerHandler('focus'); //没有光标闪烁

        })
    </script>

三、事件对象

在这里插入图片描述

 <script>
        $(function() {
            $(document).on('click', function(e) {
                console.log('点击了document');
            })
            $('div').on('click', function(e) {
                console.log('点击了div');
                e.stopPropagation();//阻止冒泡
            })
        })
    </script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值