jQuery事件

jQuery事件

事件处理on

单个事件注册
语法:
element.事件(function(){})
$(“div”).click(function(){ 事件处理程序 })
其他事件和原生基本一致
比如mouseover,mouseout,blur,focus,change,keydown,keyup,resize,scroll
事件处理 on() 绑定事件
on() 方法优势1:可以绑定多个事件,多个事件处理程序
on() 方法优势2:可以事件委派操作。事件委派的定义就是,把原来加给子元素身上的事件绑定在父元素身上,就是把事件委派给父亲

	$("ul").on("click","li",function(){
                alert("hellow world!");
            });

在此之前有bind(),live(),delegate()等方法来处理事件绑定或者委派,最新版本的请用on替代他们

on() 方法优势1:如果事件处理程序相同
	$("div").on("mouseenter mouseleave",function(){
                $(this).toggleClass("current");
            });
on() 方法优势3:可以给未来动态创建的元素绑定事件(重要)
	$("ol").on("click","li",function(){
                alert("你好!");
            });
            var li = $("<li>我是后来创建的</li>");
            $("ol").append(li);

事件处理off

事件处理 off() 解绑事件

  • off()方法可以移除通过on()方法添加的事件处理程序

  • $(“p”).off() // 解绑p元素所有事件处理程序

  • $(“p”).off(“click”) // 解绑p元素上面的点击事件

  • $(“ul”).off(“click”,“li”) // 解绑事件委托

    如果有的事件只想触发一次,可以通过one()来绑定事件

自动触发事件

有些事件希望自动触发,比如轮播图自动播放功能和点击右侧按钮一致。可以利用定时器
自动触发右侧按钮点击事件,不必鼠标点击触发
element.click() // 第一种简写方式
element.trigger(“type”) // 第二种自动触发模式
element.triggerHandler(“事件”) // 第三种自动触发模式,与上面两种方式的最大的区别就是不会触发元素的默认行为

	<div></div>
    <input type="text">
	$(function(){
            $("div").click(function(){
                alert(1);
            });
            // 1. 自动触发事件
            // 元素.事件()  element.click
            // $("div").click();
            // 2. 元素.trigger(事件)
            // $("div").trigger("click");
            // 3. 元素.triggerHandler(事件)
            // $("div").triggerHandler("click");
            $("input").focus(function(){
                $(this).val("hello world");
            });
            $("input").triggerHandler("focus");
        })

jQuery事件对象

事件被触发,就会有事件对象的产生 event就是事件对象

element.on(events,[selector],function(event){})
    阻止默认行为: event.preventDefault()  或者  return false
    阻止事件冒泡: event.stopPropagation()

jQuery对象拷贝

如果想要把某个对象拷贝(合并)给另外一个对象使用,此时可以使用$.exentd()方法
语法:

 $.extend([deep],target,object1,[objectN])

1 . deep:如果设为true为深拷贝,默认false浅拷贝
2. target:要拷贝的目标对象
3. obje11:待拷贝到第一个对象的对象
4. obje1N:待拷贝到第N个对象的对象
5. 浅拷贝是把被拷贝对象复杂数据类型中的地址拷贝给目标对象,修改目标对象会影响被拷贝对象
6. 深拷贝,前面加true,完全克隆(拷贝的对象,而不是地址),修改目标对象不会影响被拷贝对象

	$(function () {
            // 浅拷贝 把原来对象里面的复杂数据类型的地址拷贝给目标对象
            var targetObj = {
                id: 0, // 这里会被覆盖掉
                msg: {
                    name: '男' // 注意,这里的msg也会被覆盖
                }
            };
            var obj = {
                id: 1,
                name: "andy",
                msg: {
                    age: 5
                }
            };
            // $.extend(targetObj, obj);
            obj.msg.age = 10;
            console.log(targetObj)
            // 深拷贝  把里面的数据完全复制一份给目标对象,如果有不冲突的属性会合并到一起
            $.extend(true, targetObj, obj);
            console.log(targetObj);

        })

jQuery多库共存

jquery使用 $ 作为标示符,随着jquery的流行,其他js库也会用 $ 作为标识符,这样一起使用会引起冲突
客观需求:需要一个解决方案,让jQuery和其他js库不存在冲突,可以同时存在,这就叫多库共存
jQuery解决方案:
1. 把里面的 $ 符号统一改为jQuery。比如jQuery(“div”)
2. jQuery变量规定新的名称:$.noConflict() var xx = $.noConflict;

			// 1. 如果$符号冲突 我们就使用jquery
            jQuery.each();
            // 2. 让jQuery释放对$的控制权,让用户自己决定
            var suibian = jQuery.noConflict();
            console.log(suibian("div"));
            suibian.each();

jQuery尺寸位置

1. jQuery尺寸
语法用法
width()/height()取得匹配元素宽度和高度值 ,只算width/height
innerWidth()/innerHeight()取得匹配元素宽度和高度值,包含padding
outerWidth()/outerHeight()取得匹配元素宽度和高度值 包含padding,border
outerWidth(true)/outerHeight(true)取得匹配元素宽度和高度值 包含padding,border,margin

注意:以上参数为空,则是获取相应值,返回的是数字型如果参数为数字,则是修改相应值,参数可以不必写单位

1. jQuery位置

位置主要有三个: offset(),position(),scrollTop/scrollLeft()
(1)offset()设置或获取元素偏移
         ~ offset()方法设置或返回被选元素相对于 文档 的偏移坐标,跟父级没有关系
         ~ 该方法有两个属性left,top,offset().top用于获取距离文档顶部的距离,另一个同理
         ~ 可以设置元素的偏移,offset({ top:10, left::30});
(2)position()获取元素偏移
         ~ position()方法用于返回被选元素相对于带有定位的父级偏移坐标,如果父级没有定位,则以文档为准
         ~ 这个方法只能获取不能设置偏移
(3)scrollTop()/scrollLeft()设置或获取元素被卷去的头部和左侧
         ~ scrollTop()方法设置或返回被选元素被卷去的头部

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值