成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

使用jQuery監(jiān)聽DOM元素大小變化

luxixing / 1720人閱讀

摘要:但是又不知道如何為多說的評論按鈕增加回調(diào)函數(shù),于是乎就想到了根據(jù)子元素的大小變化來重新計(jì)算父元素的。平常,都是在整個(gè)瀏覽器窗口變化時(shí)觸發(fā)一個(gè)修改布局的回調(diào)函數(shù)。

起因

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

onresize?

平常,都是在整個(gè)瀏覽器窗口變化時(shí)觸發(fā)一個(gè)修改布局的回調(diào)函數(shù)。使用的是window對象的resize事件,利用:

window.onresize = callback;

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

使用jQuery事件的實(shí)現(xiàn)思路

可以想到一種比較簡單的方式:
1. 在元素綁定resize對象時(shí),記錄元素的width和height
2. 使用requestAnimationFrame、setTimeout、setInterval,每隔一段時(shí)間查詢其width和height,如果和記錄的width和height不一樣,運(yùn)行回調(diào)函數(shù)并更新記錄中的width為height

jQuery插件

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

(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插件的開發(fā)者提供了添加自定義事件的接口,詳細(xì)可以參考jQuery官方文檔,這里就是典型的jQuery自定義事件添加方式,其中有三個(gè)鉤子:
1. setup:The setup hook is called the first time an event of a particular type is attached to an element.首次綁定時(shí)執(zhí)行,如果返回 false,使用默認(rèn)方式綁定事件
2. teardown:The teardown hook is called when the final event of a particular type is removed from an element.若指定該方法,其在移除事件處理程序(removeEventListener)前執(zhí)行,如果返回 false,移除默認(rèn)綁定事件
3. add:Each time an event handler is added to an element through an API such as .on(), jQuery calls this hook.每一次給元素綁定事件,都會(huì)執(zhí)行這個(gè)方法

setup、teardown和add三個(gè)鉤子,每個(gè)鉤子最先做的事都是檢測是否該對象為window對象,然后根據(jù)window對象特殊處理,因?yàn)閣indow對象本身有resize事件

從setup鉤子可以看到,在初始化整個(gè)事件處理時(shí),創(chuàng)建一個(gè)元素隊(duì)列,隊(duì)列中的每隔元素都把width和height放在data中,然后每隔250ms啟動(dòng)loopy函數(shù),在loopy函數(shù)中判斷是否變化,如果有變,觸發(fā)回調(diào)函數(shù)并更新data中的width和height

從teardown鉤子可以看到,在元素移除事件時(shí),只需要將元素從元素隊(duì)列移除,并清除元素中的data數(shù)據(jù)。如果是元素隊(duì)列中的最后一個(gè)元素,則不再繼續(xù)執(zhí)行l(wèi)oopy

add鉤子中,對回調(diào)函數(shù)進(jìn)行了包裝

由此可以看到一個(gè)簡單的jQuery自定義函數(shù)的實(shí)現(xiàn)機(jī)制

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/87454.html

相關(guān)文章

  • js監(jiān)聽div元素的寬高變化

    摘要:構(gòu)造函數(shù),參數(shù)為回調(diào)函數(shù)構(gòu)造函數(shù)為,它在監(jiān)聽到中的改變并且一系列改變結(jié)束后觸發(fā)回調(diào)函數(shù)。是要監(jiān)聽的元素,為監(jiān)聽選項(xiàng)對象,可選的選項(xiàng)如下所以監(jiān)聽元素寬高變化,就是監(jiān)聽屬性變化這樣當(dāng)元素發(fā)生變化時(shí),就會(huì)觸發(fā)構(gòu)造函數(shù)中的函數(shù)。 一、js監(jiān)聽window變化的方法 1、onsize只能監(jiān)聽window對象的變化 (1)、 window對象原生、jQuery方法 //原生寫法 window.on...

    lansheng228 評論0 收藏0
  • 2019前端面試題匯總(主要為Vue)

    摘要:畢業(yè)之后就在一直合肥小公司工作,沒有老司機(jī)沒有技術(shù)氛圍,在技術(shù)的道路上我只能獨(dú)自摸索。于是乎,我果斷辭職,在新年開工之際來到杭州,這里的互聯(lián)網(wǎng)公司應(yīng)該是合肥的幾十倍吧。。。。 畢業(yè)之后就在一直合肥小公司工作,沒有老司機(jī)、沒有技術(shù)氛圍,在技術(shù)的道路上我只能獨(dú)自摸索。老板也只會(huì)畫餅充饑,前途一片迷??床坏饺魏蜗M?。于是乎,我果斷辭職,在新年開工之際來到杭州,這里的互聯(lián)網(wǎng)公司應(yīng)該是合肥的幾十...

    arashicage 評論0 收藏0
  • JSLite 的目標(biāo):縮小體積,做到 jQuery-free

    摘要:轉(zhuǎn)載大牛的分析,這將是的方向。域名分析據(jù)統(tǒng)計(jì),目前全世界的網(wǎng)站使用它。的市場份額不斷下降,以為基礎(chǔ)的標(biāo)準(zhǔn)語法,正得到越來越廣泛的支持。下面就探討如何用標(biāo)準(zhǔn)語法,取代的一些主要功能,做到。 轉(zhuǎn)載大牛的分析,這將是JSLite的方向。前人栽樹后人乘涼,jQuery為我們制定了一套接口標(biāo)準(zhǔn),我們繼續(xù)為此努力。域名:JSLite.io jQuery 分析 據(jù)統(tǒng)計(jì),目前全世界57.3%...

    Scott 評論0 收藏0
  • 監(jiān)聽div的resize

    摘要:上網(wǎng)找了找,對于的事件的監(jiān)聽,實(shí)現(xiàn)方式有很多,比如基于的小插件通過元素進(jìn)行監(jiān)聽來監(jiān)聽元素基于的周期性檢查雖然是實(shí)現(xiàn)了對元素寬高的監(jiān)聽,但看上去很瓜。 簡單點(diǎn)說,就是: 在被監(jiān)聽的 div 中添加 iframe 標(biāo)簽,設(shè)置其高寬均為 100%; 在 iframe 的 resize 被觸發(fā)時(shí),則表明 div 的大小正在改變! 參考 Resize on div el...

    TNFE 評論0 收藏0
  • 監(jiān)聽div的resize

    摘要:上網(wǎng)找了找,對于的事件的監(jiān)聽,實(shí)現(xiàn)方式有很多,比如基于的小插件通過元素進(jìn)行監(jiān)聽來監(jiān)聽元素基于的周期性檢查雖然是實(shí)現(xiàn)了對元素寬高的監(jiān)聽,但看上去很瓜。 簡單點(diǎn)說,就是: 在被監(jiān)聽的 div 中添加 iframe 標(biāo)簽,設(shè)置其高寬均為 100%; 在 iframe 的 resize 被觸發(fā)時(shí),則表明 div 的大小正在改變! 參考 Resize on div el...

    legendaryedu 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<