首頁 > web前端 > js教程 > 主體

jquery常用函數與方法匯總_jquery

WBOY
發布: 2016-05-16 15:41:15
原創
1105 人瀏覽過

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方法

用法範例:

<div class=”myDiv”></div>
登入後複製

jquery:

$(“.myDiv”).live(“click”, function(){
alert(“clicked!”);
});
登入後複製

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

使用live當然有利也有弊:

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

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

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

2.移除live綁定的事件

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

如:

$(“.myDiv”).die("click");
登入後複製

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

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

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

var X = $('#DivID').offset().top; 
var Y = $('#DivID').offset().left; 
登入後複製

例如:

$(".produc a span").click(function(){
 $('body, html').animate({scrollTop:$('#buy').offset().top }, 'slow');
 });
登入後複製

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

var X = $('#DivID').position().top; 
var Y = $('#DivID').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("div").stop(false,true);
  $(this).children("div").slideDown(400).end();              
},function(){
  $(this).children("a").removeClass("curr");
  $(".nav li.has_list").children("div").stop(false,true);
  $(this).children("div").slideUp(400).end();
  }
);
登入後複製

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

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板