成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? 使用jQuery監聽DOM元素大小變化
全站頭部文字 我要出現在這里
使用jQuery監聽DOM元素大小變化 654 2024-03-11   

起因

今天寫頁面的時候突然有這么個需求,由于父元素(一個DIV)的height是由javascript計算出來的固定的值,而在其中增加了一個多說插件,在用戶評論后,子元素(DIV)的height屬性增加,導致子元素溢出。但是又不知道如何為多說的評論按鈕增加回調函數,于是乎就想到了根據子元素的大小變化來重新計算父元素的height。

onresize?

平常,都是在整個瀏覽器窗口變化時觸發一個修改布局的回調函數。使用的是window對象的resize事件,利用:

window.onresize = callback;

來綁定。但根據resize事件的target是defaultView (window),這里詳見MDN的resize文檔,也就是說只有window對象有resize事件,于是乎就想到使用jQuery自己的事件機制來模擬一個普通元素上的resize事件

使用JQUERY事件的實現思路

可以想到一種比較簡單的方式:

1. 在元素綁定resize對象時,記錄元素的width和height
2. 使用requestAnimationFrame、setTimeout、setInterval,每隔一段時間查詢其width和height,如果和記錄的width和height不一樣,運行回調函數并更新記錄中的width為height

JQUERY插件

這個功能Ben Alman編寫了一個jQuery插件,傳送門
該插件的代碼(核心部分),詳細代碼請查看Ben Alman博客的內容:

(function($, window, undefined) {
 var elems = $([]),
  jq_resize = $.resize = $.extend($.resize, {}),
  timeout_id,
  str_setTimeout = 'setTimeout',
  str_resize = 'resize',
  str_data = str_resize + '-special-event',
  str_delay = 'delay',
  str_throttle = 'throttleWindow';
 jq_resize[str_delay] = 250;
 jq_resize[str_throttle] = true;
 $.event.special[str_resize] = {
  setup: function() {
   if (!jq_resize[str_throttle] && this[str_setTimeout]) {
    return false;
   }
   var elem = $(this);
   elems = elems.add(elem);
   $.data(this, str_data, {
    w: elem.width(),
    h: elem.height()
   });
   if (elems.length === 1) {
    loopy();
   }
  },
  teardown: function() {
   if (!jq_resize[str_throttle] && this[str_setTimeout]) {
    return false;
   }
   var elem = $(this);
   elems = elems.not(elem);
   elem.removeData(str_data);
   if (!elems.length) {
    clearTimeout(timeout_id);
   }
  },
  add: function(handleObj) {
   if (!jq_resize[str_throttle] && this[str_setTimeout]) {
    return false;
   }
   var old_handler;
   function new_handler(e, w, h) {
    var elem = $(this),
     data = $.data(this, str_data);
    data.w = w !== undefined ? w : elem.width();
    data.h = h !== undefined ? h : elem.height();
    old_handler.apply(this, arguments);
   }
   if ($.isFunction(handleObj)) {
    old_handler = handleObj;
    return new_handler;
   } else {
    old_handler = handleObj.handler;
    handleObj.handler = new_handler;
   }
  }
 };

 function loopy() {
  timeout_id = window[str_setTimeout](function() {
   elems.each(function() {
    var elem = $(this),
     width = elem.width(),
     height = elem.height(),
     data = $.data(this, str_data);
    if (width !== data.w || height !== data.h) {
     elem.trigger(str_resize, [data.w = width, data.h = height]);
    }
   });
   loopy();
  }, jq_resize[str_delay]);
 }
})(jQuery, this);

jQuery為jQuery插件的開發者提供了添加自定義事件的接口,詳細可以參考jQuery官方文檔,這里就是典型的jQuery自定義事件添加方式,其中有三個鉤子:

1. setup:The setup hook is called the first time an event of a particular type is attached to an element.首次綁定時執行,如果返回 false,使用默認方式綁定事件
2. teardown:The teardown hook is called when the final event of a particular type is removed from an element.若指定該方法,其在移除事件處理程序(removeEventListener)前執行,如果返回 false,移除默認綁定事件
3. add:Each time an event handler is added to an element through an API such as .on(), jQuery calls this hook.每一次給元素綁定事件,都會執行這個方法

setup、teardown和add三個鉤子,每個鉤子最先做的事都是檢測是否該對象為window對象,然后根據window對象特殊處理,因為window對象本身有resize事件

從setup鉤子可以看到,在初始化整個事件處理時,創建一個元素隊列,隊列中的每隔元素都把width和height放在data中,然后每隔250ms啟動loopy函數,在loopy函數中判斷是否變化,如果有變,觸發回調函數并更新data中的width和height

從teardown鉤子可以看到,在元素移除事件時,只需要將元素從元素隊列移除,并清除元素中的data數據。如果是元素隊列中的最后一個元素,則不再繼續執行loopy

add鉤子中,對回調函數進行了包裝

由此可以看到一個簡單的jQuery自定義函數的實現機制



主站蜘蛛池模板: 陕西卫视节目表| h罩杯美女| gale harold| 画魂缠身 电影| 精灵变粤语| 庆余年2演员表全部员表| 河东舞曲的士高| 九号所有车型图片| 电影《男宠》在线观看| 一代宗师 豆瓣| 美女下面流水| 桥段| 超在线视频| 郑业成个人详细简历| 铃芽之旅豆瓣| 四级词汇电子版| 硅胶娃娃实战视频| 战犬出击电影完整版免费观看| 甜蜜蜜电影粤语无删减版| 庆余年2豆瓣| 香谱72图解高清大图及解释| 男女高清视频| 釜山国际电影节| 情满四合院46集免费播放电视剧| 正义回廊 电影| 一年级数学小报简单又漂亮模板| 台版缉魂2小时10分版网飞版| 失落的星球| 视频污污| 一路向东电影| 蓝家宝电影| 盲道电影| 黑木美纱| 马会传真论坛13297соm查询官网| 丧尸童子军| 艳妇乳肉豪妇荡乳xxx| 富二代| 最新电影在线| 恶魔女忍者| 真爱复苏| 万万没想到第三季|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103