Home  >  Article  >  Web Front-end  >  Give you an in-depth understanding of the Bind() function in JQuery

Give you an in-depth understanding of the Bind() function in JQuery

巴扎黑
巴扎黑Original
2017-06-25 11:03:151548browse

This article mainly introduces the usage of Bind() event in JQuery. It analyzes the function, characteristics and usage skills of Bind() event with examples. Friends in need can refer to this article

The example analyzes the usage of Bind() event in JQuery. Share it with everyone for your reference. The specific analysis is as follows:

Let’s take a look at its definition first:


.bind( eventType [, eventData], handler(eventObject))

. The main function of the Bind() method is to bind the object to it The above provides some behavior of event methods. The meanings of its three parameters are as follows:

eventType is a string type event type, which is the event you need to bind. Such types can include the following: blur, focus, focusin, focusout, load, resize, scroll, unload, click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, mouseenter, mouseleave, change, select, submit, keydown, keypress , keyup, error. What needs to be noted here is that the event methods in JavaScript are used here, not in JQuery. The event methods in JQuery all have an extra "on" in front of JavaScript, such as onclick, onblur, etc.

The eventData parameter is an optional parameter, but it is rarely used in normal times. If this parameter is provided, then we can pass some additional information to the Event handling function. This parameter has a good use, which is to deal with problems caused by closures. I will give you an example later.

Handler is the processing number used for binding, which is actually the callback function, the corresponding method after processing the data.

1. The first simple bind () event---Hello Word


<input id="BtnFirst"type="button"value="Click Me"/>
<script>
$(function () {
 $("#BtnFirst").bind("click",function(){
  alert("Hello World");
 });
})
</script>

After opening the page, click the button "Click Me", "Hello World" will pop up. This is our simplest binding event. It's very simple.

2. Bind multiple events

We can bind multiple events through bind() (in fact, this is also a very famous event in JQuery and Linq Chain programming). The main function implemented is that when we click, "Hello World" pops up, and when we leave the button, a p is displayed.


<p>
<input id="BtnFirst"type="button"value="Click Me"/></p>
<p id="Testp"style=" width:200px; height:200px; display:none; ">
</p>
<script>
$(function () {
 $("#BtnFirst").bind("click", function () {
  alert("Hello World");
 }).bind("mouseout", function () {
  $("#Testp").show("slow");
 });
})
</script>

This code page is easy to understand. When the button is clicked, a "Hello World" will pop up. When leaving, the p will be displayed. . For animations in JQuery, you can use "slow", "fast" and "normal". Of course, you can also set the relevant milliseconds.

3.bind() event object

Handler callback function can accept a parameter, when this function is called, a JavaScript event object will be passed in as a parameter.

Give me an example from the JQuery official website:


<style> 
 p {background:yellow;font-weight:bold;cursor:pointer;3 padding:5px;}
 p.over {background:#ccc;}
 span {color:red;}
</style>
<p>Click or double click here.</p>
<span></span>
<script>
 $("p").bind("click", function(event){
  var str = "( " + event.pageX + ", " + event.pageY + " )";
  $("span").text("Click happened! " + str);
 });
 $("p").bind("dblclick", function(){
  $("span").text("Double-click happened in " + this.nodeName);
 });
 $("p").bind("mouseenter mouseleave", function(event){
  $(this).toggleClass("over");
 });
</script>

The main function here is to realize that when the user clicks on the p object, the current relative to The coordinates of the page are displayed in the span tag, and the event event is used here. Pass the parameters in.

4.unbind() event

unbind([type],[data],Handler) is the reverse operation of bind(), starting from each matching Remove the bound event from the element. If there are no parameters, all bound events are deleted. You can unbind custom events you registered with bind(). If an event type is provided as a parameter, only bound events of that type are removed. If a handler is passed as the second argument when binding, only that specific event handler will be removed.


<body onclick="MyBodyClick()">
 <p onclick="MyClickOut()">
  <p onclick="MyClickInner()">
   <span id="MySpan">I love JQuery!! </span>
  </p>
 </p>
 <span id="LooseFocus">失去焦点</span>
</body>
<script>
function MyClickOut() {
 alert("outer p");
}
function MyClickInner() {
 alert("Inner p");
}
function MyBodyClick() {
 alert("Body Click");
}
var foo = function () {
 alert("I&#39;m span.");
}
$(function () {
 $("#MySpan").bind("click", foo);
})  
$(function () {
 $("#LooseFocus").unbind("click", foo);
})
</script>

The above code is also easy to understand. When the user's mouse stays on the span, the click event of the span is then cancelled. So, in the end it will only pop up the alert inside the body.

Finally, let’s briefly understand the use of one() event. In fact, one and bind are the same, both are generated for binding events. One is basically the same as bind. The difference is that when calling jQuery.event.add, the registered event processing function is slightly adjusted. One called jQuery.event.proxy to proxy the incoming event processing function. When an event triggers a call to this agent's function, the event is first deleted from the cache, and then the registered event function is executed. Here is the application of closure, through which the reference of the event function registered by fn is obtained.

Usage rules:


one(type,[data],fn)

Bind a one-time event handler function for each specific event (like click) of the matching element. This event handler is executed only once on each object. Other rules are the same as bind() function. This event handler will receive an event object, which can be used to prevent the default behavior. If you want to cancel the default behavior and prevent the event from bubbling, the event handler must return false.

Post it, the implementation of the respective codes of bind and one, the reader can make a slight comparison:

The implementation of the Bind() code:


bind : function(type, data, fn) { 
 return type == "unload" ? this.one(type,data,fn) : this.each(function(){
 //fn || data, fn && data实现了data参数可有可无 
  jQuery.event.add(this, type, fn || data, fn && data); 
 }); 
}

Implementation of One() code:


one : function(type, data, fn) { 
 var one = jQuery.event.proxy(fn || data, function(event) { 
  jQuery(this).unbind(event, one); 
  return (fn || data).apply(this, arguments);
 //this->当前的元素 
 }); 
 return this.each(function() { 
  jQuery.event.add(this, type, one, fn && data); 
 }); 
}

5.最后呢,其实想在贴一个冒泡事件,因为在处理绑定事件的时候,如果调用内部的事件 有可能会触发外面的事件,所以给大伙一个借鉴吧。

这里可以参考一下javascript事件冒泡的文章:《JavaScript 事件冒泡简介及应用》。

简单的说,何为冒泡事件?其实,简单的理解是,也可以说是事件传播,它会从内部的控件广播到父类的元素,然后接着一直往上到祖先级别的元素。

则 冒泡实例代码:


<body onclick="MyBodyClick()">
 <p onclick="MyClickOut()">
  <p onclick="MyClickInner()">
    <span id="MySpan">
     I love JQuery!!
    </span>
  </p>
 </p>
</body>
<script type="text/javascript">
 function MyClickOut() {
  alert("outer p");
 }
 function MyClickInner() {
  alert("Inner p");
 }
 function MyBodyClick() {    
  alert("Body Click");
 }
 $(function () {
  $("#MySpan").bind("click", function (event) {
   alert("I&#39;m span");
   event.stopPropagation();
 });
</script>

The above is the detailed content of Give you an in-depth understanding of the Bind() function in JQuery. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn