欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jQuery hover 延時器實現(xiàn)代碼

 更新時間:2011年03月12日 21:48:48   作者:  
在上一篇文章 《鼠標(biāo)事件延時切換插件》 中,我已經(jīng)寫了幾個簡單的延時器的例子,今天突然想到j(luò)Query的自定義動畫的animate方法可以使用delay
例如:
復(fù)制代碼 代碼如下:

$('#foo').slideUp(300).delay(800).fadeIn(400);// 在.slideUp() 和 .fadeIn()之間延時800毫秒。

hover是否可以設(shè)計一個延時器呢?答案是肯定的。延時操作目的是為了防止用戶誤觸發(fā)事件,一般情況下鼠標(biāo)指針小于150毫秒的停留時間都可以被忽略。其實,如果入侵delay全能讓其作用在hover事件上,但是為了避免John Resig不斷的折騰jQuery而導(dǎo)致兼容問題,還是老老實實的寫標(biāo)準(zhǔn)插件比較好。
目標(biāo)
繼承jQuery API的優(yōu)雅:jQuery(expression).mouseDelay(150).hover(over, out)
不得破壞jQuery原型鏈
上述目標(biāo)看起來很帥氣,實現(xiàn)起來卻非常簡單,僅僅十多行的代碼我都不好意思拿來拼湊文章:
源代碼
復(fù)制代碼 代碼如下:

/*!
* jQuery.mouseDelay.js v1.2
* http://www.planeart.cn/?p=1073
* Copyright 2011, TangBin
* Dual licensed under the MIT or GPL Version 2 licenses.
*/
(function ($, plugin) {
var data = {}, id = 1, etid = plugin + 'ETID';
// 延時構(gòu)造器
$.fn[plugin] = function (speed, group) {
id ++;
group = group || this.data(etid) || id;
speed = speed || 150;
// 緩存分組名稱到元素
if (group === id) this.data(etid, group);
// 暫存官方的hover方法
this._hover = this.hover;
// 偽裝一個hover函數(shù),并截獲兩個回調(diào)函數(shù)交給真正的hover函數(shù)處理
this.hover = function (over, out) {
over = over || $.noop;
out = out || $.noop;
this._hover(function (event) {
var elem = this;
clearTimeout(data[group]);
data[group] = setTimeout(function () {
over.call(elem, event);
}, speed);
}, function (event) {
var elem = this;
clearTimeout(data[group]);
data[group] = setTimeout(function () {
out.call(elem, event);
}, speed);
});
return this;
};
return this;
};
// 凍結(jié)選定元素的延時器
$.fn[plugin + 'Pause'] = function () {
clearTimeout(this.data(etid));
return this;
};
// 靜態(tài)方法
$[plugin] = {
// 獲取一個唯一分組名稱
get: function () {
return id ++;
},
// 凍結(jié)指定分組的延時器
pause: function (group) {
clearTimeout(data[group]);
}
};
})(jQuery, 'mouseDelay');

API說明

方法 參數(shù) 說明
mouseDelay (speed, group) 速度, 設(shè)置延時分組名稱 設(shè)置延時觸發(fā)效果. 兩個參數(shù)都是可選的
mouseDelayPause() [無] 凍結(jié)選定元素的延時器
jQuery.mouseDelay.pause (group) 延時分組名稱 凍結(jié)指定分組的延時器
jQuery.mouseDelay.get () [無] 獲取一個不重復(fù)的分組名
下載


演示 

http://demo.jb51.net/js/2011/mouseDelay/index.htm

打包下載

planeArt.cn原創(chuàng)文章

相關(guān)文章

  • 基于jQuery的網(wǎng)頁右下角彈出廣告(IE7,firefox)

    基于jQuery的網(wǎng)頁右下角彈出廣告(IE7,firefox)

    以前曾寫過一個,不過太麻煩了,呵呵```現(xiàn)在改進(jìn)了一下,其實很簡單:css定位層一直在右下角,用js控制層的高度增減。
    2010-08-08
  • jQuery隨機(jī)切換圖片的小例子

    jQuery隨機(jī)切換圖片的小例子

    jQuery隨機(jī)切換圖片的小例子,需要的朋友可以參考一下
    2013-04-04
  • jquery入門—選擇器實現(xiàn)隔行變色實例代碼

    jquery入門—選擇器實現(xiàn)隔行變色實例代碼

    JQuery入門—選擇器實現(xiàn)隔行變色如何實現(xiàn)呢?JQuery選擇器繼承了CSS、path語音的部分語法,允許通過標(biāo)簽名、屬性名、內(nèi)容對DOM元素進(jìn)行快速、準(zhǔn)確的選擇,接下來詳細(xì)介紹,需要的朋友可以參考下
    2013-01-01
  • 用jquery設(shè)置按鈕的disabled屬性的實現(xiàn)代碼

    用jquery設(shè)置按鈕的disabled屬性的實現(xiàn)代碼

    在html標(biāo)簽中設(shè)置按鈕被禁用,可以使用如下代碼
    2010-11-11
  • jquery簡易手風(fēng)琴插件的封裝

    jquery簡易手風(fēng)琴插件的封裝

    這篇文章主要為大家詳細(xì)介紹了jquery簡易手風(fēng)琴插件的封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • jQuery實現(xiàn)表單驗證

    jQuery實現(xiàn)表單驗證

    這篇文章主要為大家詳細(xì)介紹了jQuery實現(xiàn)表單驗證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • jquery.validate分組驗證代碼

    jquery.validate分組驗證代碼

    在很多時候,我們都不是一步就將所有信息填寫完整,然后提交。而是分步進(jìn)行填寫表單
    2011-03-03
  • 快速實現(xiàn)jQuery多級菜單效果

    快速實現(xiàn)jQuery多級菜單效果

    這篇文章主要教大家如何快速實現(xiàn)jQuery多級菜單效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • jQuery Ajax之load()方法

    jQuery Ajax之load()方法

    jQuery對Ajax操作進(jìn)行了封裝,在jQuery中$.ajax()方法屬于最底層的方法,第2層是laod()、$.get()和$.post()方法,第3層是$.getScript()和$.getJSON()方法。
    2009-10-10
  • jQuery.extend 函數(shù)及用法詳細(xì)

    jQuery.extend 函數(shù)及用法詳細(xì)

    Jquery的擴(kuò)展方法extend是我們在寫插件的過程中常用的方法,該方法有一些重載原型,在此,我們一起通過本篇文章學(xué)習(xí)jquery.extend函數(shù)及用法詳解吧
    2015-09-09

最新評論