首頁  >  文章  >  web前端  >  jquery有哪些函數

jquery有哪些函數

藏色散人
藏色散人原創
2020-11-26 11:35:183533瀏覽

jquery函數有:1、「delay(duration,[queueName])」函數;2、「jQuery live( type, fn )」函數;3、「.live()」函數;4、「 position()」函數;5、「stop()」函數等等。

jquery有哪些函數

推薦:《jquery教學

  • 此方法適用於所有品牌電腦。

jquery常用函數與方法匯總

1.delay(duration,[queueName])

#設定一個延時來延遲執行佇列中之後的項目。

jQuery 1.4新增。用於將佇列中的函數延時執行。他既可以推遲動畫隊列的執行,也可以用於自訂隊列。

duration:延遲時間,單位:毫秒

queueName:佇列名詞,預設是Fx,動畫佇列。

範例:

頭部與底部延遲載入動畫效果

$(document).ready(function() {
  $('#header') .css({ 'top':-50 }) .delay(1000).animate({'top': 0}, 800);
  $('#footer') .css({ 'bottom':-15 }) .delay(1000).animate({'bottom': 0}, 800); 
});

#2.jQuery live( type, fn ) 委派事件實作

#Query 1.3新增的方法。給所有目前以及將來會匹配的元素綁定一個事件處理函數(例如click事件)。也能綁定自訂事件。

目前支援 click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, keydown, keypress, keyup。

還不支援 blur, focus, mouseenter, mouseleave, change, submit

與bind()不同的是,live()一次只能綁定一個事件。

這個方法跟傳統的bind很像,差別在於用live來綁定事件會給所有當前以及將來在頁面上的元素綁定事件(使用委派的方式)。比如說,如果你給頁面上所有的li用live綁定了click事件。那麼當在以後增加一個li到這個頁面時,對於這個新增加的li,其click事件依然可用。而無需重新給予這種新增加的元素綁定事件。

.live()與流行的liveQuery外掛很像,但有以下幾個主要區別:

.live 目前只支援所有事件的子集,支持列表參考上面的說明。

.live 不支援liveQuery提供的「無事件」樣式的回呼函數。 .live只能綁定事件處理函數。

.live 沒有”setup」和”cleanup」的過程。因為所有的事件是委派而不是直接綁定在元素上的。

要移除用live綁定的事件,請用die方法

用法範例:

<p class=”myp”></p>

jquery:

$(“.myp”).live(“click”, function(){
alert(“clicked!”);
});

如果使用javascript動態建立一個class為myp的元素,點擊元素仍然會有彈出。為什麼使用live後就有了呢?這是因為jquery利用了事件的冒泡機制,直接把事件綁定在了document上,然後透過event.target找出事件的來源。這跟jquery.livequery外掛不一樣,jquery.livequery每20毫秒做一次檢查,如有新生成則重新綁定一次事件。

使用live當然有利也有弊:

好處就是:元素更新時不用重複定義事件。

壞處就是:把事件綁定在document上會在頁面上每個元素都呼叫一次,如使用不當會嚴重影響效能。

而且不支援blur, focus, mouseenter, mouseleave, change, submit。

2.移除live綁定的事件

在Jquery裡,使用live來綁定事件,若想移除事件,要使用die方法。

如:

$(“.myp”).die("click");

這樣就好將綁定的click事件移除掉。

3.JQuery offset(),position()得到絕對,相對位置的座標方法

取得頁面某一元素的絕對X,Y座標,可以用offset()方法:(body屬性設定margin :0;padding:0;)

var X = $(&#39;#pID&#39;).offset().top; 
var Y = $(&#39;#pID&#39;).offset().left;

例如:

$(".produc a span").click(function(){
 $(&#39;body, html&#39;).animate({scrollTop:$(&#39;#buy&#39;).offset().top }, &#39;slow&#39;);
 });

取得相對(父元素)位置:

var X = $(&#39;#pID&#39;).position().top; 
var Y = $(&#39;#pID&#39;).position().left; 
var left = $("selector").offset().left;//元素相当于窗口的左边的偏移量
var top = $("selector").offset().top;//元素相对于窗口的上边的偏移量
var pleft = $("selector").scrollLeft();//元素相对于滚动条左边的偏移量
var pTop = $("selector").scrollTop();//元素相对于滚动条顶部的偏移量

4.jquery取得滑鼠位置

 $(function () {
      //e为事件名;
      $(document).mousemove(function (e) {
        $("p").text("X:" + e.pageX + "  Y:" + e.pageY);
      });

    });

5.jquery判斷某個元素是否含有某個class,是否存在某些屬性,怎麼移除某些屬性。

在JQuery編碼中,我們會判斷元素是否存在某個屬性.例如是否包含class="new" 的樣式呢.JQuery判斷就非常簡單了,因為有hasClass這個方法$( "input[name=new]").hasClass("new") 即可判斷.

這時就沒有現成的方法了. 如果存在某個屬性$("#aid") .attr("rel") 會傳回rel的值,如果不存在rel屬性則會回傳"undefined"
undefined 就是undefined型別, if($("#aid").attr("rel")== "undefined") 這個判斷可能不成立.
因為型別不同.

建議使用if(typeof($("#aid").attr("rel"))==" undefined") 即可。

jquery移除某個jquery物件的某個屬性: $(".main").removeAttr("style");

6.jquery stop()的用法(清除動畫累積的有效方法)

#

1、stop([stopAll], [gotoEnd])方法有两个参数(当然可以不传或直传一个),其中stopAll的意思是清除之后的所有动画。gotoEnd的意思是,执行完当前动画。

2、stopAll == true时,停止队列中的所有动画, stopAll ==false时,只停止队列中的当前动画,后续动画继续执行。

3、gotoEnd == true时,立即跳到当前动画的末尾, gotoEnd ==false时,停在当前状态。且gotoEnd只有在设置了stopAll的时候才起作用

4、在项目中,如果不进行动画队列清理,就会产生动画积累的问题。因此在写入动画时,最好先清除队列中的重复动画。

在项目中,例如做下拉二级导航效果,用到jquery的slideDown()与slideUp()方法,当鼠标快速晃动后,如果不进行动画队列清理,就会产生动画积累,出现问题。

例如:

$(".nav li.has_list").hover(function(){
  $(this).children("a").addClass("curr");
  $(".nav li.has_list").children("p").stop(false,true);
  $(this).children("p").slideDown(400).end();              
},function(){
  $(this).children("a").removeClass("curr");
  $(".nav li.has_list").children("p").stop(false,true);
  $(this).children("p").slideUp(400).end();
  }
);

以上内容就是本文关于jquery常用函数与方法汇总,希望大家喜欢。

以上是jquery有哪些函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn