Web前端基础(18):jQuery基础(五)

1. 事件 

前面咱们介绍完js的事件流的概念以后,相信你们对事件流也有所了解了。那么接下来咱们看一下jquery的事件操做。javascript

在说jquery的每一个事件以前,咱们先来看一下事件对象 。java

1.1 事件对象

Event 对象表明事件的状态,好比事件在其中发生的元素、键盘按键的状态、鼠标的位置、鼠标按钮的状态。jquery

1.何时会产生Event 对象呢? 浏览器

例如: 当用户单击某个元素的时候,咱们给这个元素注册的事件就会触发,该事件的本质就是一个函数,而该函数的形参接收一个event对象。app

2.事件一般与函数结合使用,函数不会在事件发生前被执行!函数

1.2 事件流的由来

因为微软和网景乱搞,后来必需要为事件传播机制,制定一个标准,由于事件捕获是网景公司开发出来的,而事件冒泡是由微软公司开发出来的,它们都想要本身的技术成为标准,因此致使这两个公司总是干架,制定标准的人为了避免让它们干架,因此研发了事件流。性能

1.3 关于event对象

在触发的事件的函数里面咱们会接收到一个event对象,经过该对象咱们须要的一些参数,好比说咱们须要知道此事件做用到谁身上了,就能够经过event的属性target来获取到(IE暂且不谈),或者想阻止浏览器的默认行为能够经过方法preventDefault()来进行阻止。如下是event对象的一些属性和方法:this

属性spa

描述代理

altKey

返回当事件被触发时,”ALT” 是否被按下。

button

返回当事件被触发时,哪一个鼠标按钮被点击。

clientX

返回当事件被触发时,鼠标指针的水平坐标。

clientY

返回当事件被触发时,鼠标指针的垂直坐标。

ctrlKey

返回当事件被触发时,”CTRL” 键是否被按下。

metaKey

返回当事件被触发时,”meta” 键是否被按下。

relatedTarget

返回与事件的目标节点相关的节点。

screenX

返回当某个事件被触发时,鼠标指针的水平坐标。

screenY

返回当某个事件被触发时,鼠标指针的垂直坐标。

shiftKey

返回当事件被触发时,”SHIFT” 键是否被按下

IE属性(除了上面的鼠标/事件属性,IE 浏览器还支持下面的属性)。

属性

描述

cancelBubble

若是事件句柄想阻止事件传播到包容对象,必须把该属性设为 true。

fromElement

对于 mouseover 和 mouseout 事件,fromElement 引用移出鼠标的元素。

keyCode

对于 keypress 事件,该属性声明了被敲击的键生成的 Unicode 字符码。对于 keydown 和 keyup

offsetX,offsetY

发生事件的地点在事件源元素的坐标系统中的 x 坐标和 y 坐标。

returnValue

若是设置了该属性,它的值比事件句柄的返回值优先级高。把这个属性设置为

srcElement

对于生成事件的 Window 对象、Document 对象或 Element 对象的引用。

toElement

对于 mouseover 和 mouseout 事件,该属性引用移入鼠标的元素。

x,y

事件发生的位置的 x 坐标和 y 坐标,它们相对于用CSS动态定位的最内层包容元素。

标准 Event 属性,下面列出了 2 级 DOM 事件标准定义的属性。

属性和方法

描述

bubbles

返回布尔值,指示事件是不是起泡事件类型。

cancelable

返回布尔值,指示事件是否可拥可取消的默认动做。

currentTarget

返回其事件监听器触发该事件的元素。

eventPhase

返回事件传播的当前阶段。

target

返回触发此事件的元素(事件的目标节点)。

timeStamp

返回事件生成的日期和时间。

type

返回当前 Event 对象表示的事件的名称。

initEvent()

初始化新建立的 Event 对象的属性。

preventDefault()

通知浏览器不要执行与事件关联的默认动做。

stopPropagation()

再也不派发事件。

1.4 Event对象的一些兼容性写法

得到event对象兼容性写法 
event || (event = window.event);

得到target兼容型写法 
event.target||event.srcElement

阻止浏览器默认行为兼容性写法 
event.preventDefault ? event.preventDefault() : (event.returnValue = false);

阻止冒泡写法 
event.stopPropagation ? event.stopPropagation() : (event.cancelBubble = true);

2. 事件的绑定和解绑

2.1 绑定事件

语法:

bind(type,data,fn)

描述:为每个匹配元素的特定事件(像click)绑定一个事件处理器函数。

参数解释:

type (String) : 事件类型

data (Object) : (可选) 做为event.data属性值传递给事件对象的额外数据对象

fn ( Function) : 绑定到每一个匹配元素的事件上面的处理函数

示例:

当每一个p标签被点击的时候,弹出其文本 

$("p").bind("click", function(){
  alert( $(this).text() );
});

你能够在事件处理以前传递一些附加的数据。

function handler(event) {
//event.data 能够获取bind()方法的第二个参数的数据
  alert(event.data.foo);
}
$("p").bind("click", {foo: "bar"}, handler)

经过返回false来取消默认的行为并阻止事件起泡。

$("form").bind("submit", function() { return false; })

经过使用 preventDefault() 方法只取消默认的行为。

$("form").bind("submit", function(event){
  event.preventDefault();
});

2.2 解绑事件

语法:

unbind(type,fn);

描述:

bind()的反向操做,从每个匹配的元素中删除绑定的事件。

若是没有参数,则删除全部绑定的事件。

若是把在绑定时传递的处理函数做为第二个参数,则只有这个特定的事件处理函数会被删除。

参数解释:

type (String) : (可选) 事件类型

fn(Function) : (可选) 要从每一个匹配元素的事件中反绑定的事件处理函数

示例:

把全部段落的全部事件取消绑定

$("p").unbind()

将段落的click事件取消绑定

$("p").unbind( "click" )

删除特定函数的绑定,将函数做为第二个参数传入

var foo = function () {
  //绑定事件和解绑事件的事件处理函数
};

$("p").bind("click mouseenter", foo); // 给p段落绑定click mouseenter事件

$("p").unbind("click", foo); // 只解绑了p段落标签的click事件

2.3 自定义事件

其实事件的绑定和解绑,都是我为了自定义事件作准备(你们把jQuery的提供的事件熟记在心),之后对jquery熟了之后,能够玩一下自定义事件

语法:

trigger(type,data);

描述:在每个匹配的元素上触发某类事件,它触发的是由bind()注册的自定义事件。

参数解释:

type (String) : 要触发的事件类型

data (Array) : (可选)传递给事件处理函数的附加参数

示例:

给一个按钮添加自定义的事件

$('button').bind('myClick',function(ev,a,b){
    //给button按钮添加的自定义事件myClick事件        
})

而后经过trigger()触发自定义的事件

$('button').trigger('myClick',[1,2])  

 

3. 事件委托(代理)

通俗的讲,事件就是onclick,onmouseover,onmouseout,等就是事件,委托呢,就是让别人来作,这个事件原本是加在某些元素上的,然而你却加到别人身上来作,完成这个事件。
举个列子:有三个同事预计会在周一收到快递。为签收快递,有两种办法:一是三我的在公司门口等快递;二是委托给前台MM代为签收。现实当中,咱们大都采用委托的方案(公司也不会容忍那么多员工站在门口就为了等快递)。前台MM收到快递后,她会判断收件人是谁,而后按照收件人的要求签收,甚至代为付款。这种方案还有一个优点,那就是即便公司里来了新员工(无论多少),前台MM也会在收到寄给新员工的快递后核实并代为签收。

原理:

利用冒泡的原理,把事件加到父级上,触发执行效果。

做用:

1.性能要好
2.针对新建立的元素,直接能够拥有事件

事件源 :

跟this做用同样(他不用看指向问题,谁操做的就是谁),event对象下的。

使用情景:

为DOM中的不少元素绑定相同事件。

为DOM中尚不存在的元素绑定事件。

示例:

<body>
        <ul>
            <li class="luffy">路飞</li>
            <li>路飞</li>
            <li>路飞</li>
            
        </ul>
</body>
<script src="jquery-3.2.1.js"></script>
<script type="text/javascript">
$(document).ready(function(){
    
    //经过on()方法
     $('ul').on('click','#namei,.luffy',function(){
        console.log(this);
       })
            
   //将来追加的元素 
    $('ul').append('<a id="namei">娜美</a>')

}
</script>

语法:

on(type,selector,data,fn);

描述:在选定的元素上绑定一个或多个事件处理函数

参数解释:
events( String) : 一个或多个空格分隔的事件类型
selector( String) : 一个选择器字符串,用于过滤出被选中的元素中能触发事件的后代元素
data: 当一个事件被触发时,要传递给事件处理函数的 event.data
fn:回调函数
相关文章
相关标签/搜索