jquery函數有:1、「delay(duration,[queueName])」函數;2、「jQuery live( type, fn )」函數;3、「.live()」函數;4、「 position()」函數;5、「stop()」函數等等。
推薦:《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方法
用法範例:
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 = $('#pID').offset().top; var Y = $('#pID').offset().left;
例如:
$(".produc a span").click(function(){ $('body, html').animate({scrollTop:$('#buy').offset().top }, 'slow'); });
取得相對(父元素)位置:
var X = $('#pID').position().top; var Y = $('#pID').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中文網其他相關文章!