• 重庆建川博物馆正式开馆 唐良智调研部分场馆 2019-10-07
  • 斯柯达Kodiaq RS谍照 10月巴黎车展亮相 2019-10-05
  • 鄠邑区主城区因降雨集中积水严重 部分路段临时交通管制 2019-09-29
  • 多证合一 全国核发新版营业执照900余万张 2019-09-29
  • 粽情粽意 传承文明———我们的节日2018端午节 2019-09-28
  • 特朗普威胁中国,如果中国报复性征收美国高关税,美国将征收中国额外关税,特朗普真流氓。难道中国是吓大的? 2019-09-28
  • 父债子偿家不和 法官亲情促调解 2019-09-28
  • 小偷入室盗窃被抓后反教训失主晚上别开着门睡觉 2019-09-24
  • 世界各国因为势不如人,所以才会对美国的进逼忍气吞声。美国现在说话意味已不在有什么掩盖,明显的霸权主义威胁意味甚浓!特朗普的冒险性格,让世界处于危险之中!... 2019-09-09
  • 全国百家网络媒体全媒体记者彭水采风活动 2019-09-09
  • 用个例来抹黑个国家,有你这么无耻的吗?西方银行倒闭案少了吗? 2019-09-06
  • 中美智库联合报告:停止贸易战符合中美双方利益 2019-09-06
  • “拖稿”也自信 美女作家落落来渝聊新书 2019-09-03
  • 中央网信办负责人进网站宣讲党的十九大精神 2019-09-03
  • 农民回答风水神,“勤劳的农民玩什么没有富起来”。(原创首发) 2019-09-02
  • Jquery中文网 南粤风采36选7开奖公告 www.77402m.com
    Jquery中文网 >  jQuery  >  jquery 教程  >  正文 使用jQuery监听DOM元素大小变化

    南粤风采36选7中奖规则:使用jQuery监听DOM元素大小变化

    发布时间:2016-09-19   编辑:南粤风采36选7开奖公告 www.77402m.com
    jquery中文网为您提供使用jQuery监听DOM元素大小变化等资源,欢迎您收藏本站,我们将为您提供最新的使用jQuery监听DOM元素大小变化资源

    起因

    南粤风采36选7开奖公告 www.77402m.com 今天写页面的时候突然有这么个需求,由于父元素(一个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自定义函数的实现机制

    您可能感兴趣的文章:
    jQuery的运行机制和设计理念分析
    网站如何做到完全不需要jQuery也可以满足简单需求
    jQuery 事件的命名空间简单了解
    jQuery 性能优化指南(2)
    jquery ready函数源代码研究
    不要使用jQuery触发原生事件的方法
    jquery中的事件处理详细介绍
    autoIMG 基于jquery的图片自适应插件代码
    jQuery中的.bind()、.live()和.delegate()之间区别分析
    JQuery UI的拖拽功能实现方法小结

    [关闭]
  • 重庆建川博物馆正式开馆 唐良智调研部分场馆 2019-10-07
  • 斯柯达Kodiaq RS谍照 10月巴黎车展亮相 2019-10-05
  • 鄠邑区主城区因降雨集中积水严重 部分路段临时交通管制 2019-09-29
  • 多证合一 全国核发新版营业执照900余万张 2019-09-29
  • 粽情粽意 传承文明———我们的节日2018端午节 2019-09-28
  • 特朗普威胁中国,如果中国报复性征收美国高关税,美国将征收中国额外关税,特朗普真流氓。难道中国是吓大的? 2019-09-28
  • 父债子偿家不和 法官亲情促调解 2019-09-28
  • 小偷入室盗窃被抓后反教训失主晚上别开着门睡觉 2019-09-24
  • 世界各国因为势不如人,所以才会对美国的进逼忍气吞声。美国现在说话意味已不在有什么掩盖,明显的霸权主义威胁意味甚浓!特朗普的冒险性格,让世界处于危险之中!... 2019-09-09
  • 全国百家网络媒体全媒体记者彭水采风活动 2019-09-09
  • 用个例来抹黑个国家,有你这么无耻的吗?西方银行倒闭案少了吗? 2019-09-06
  • 中美智库联合报告:停止贸易战符合中美双方利益 2019-09-06
  • “拖稿”也自信 美女作家落落来渝聊新书 2019-09-03
  • 中央网信办负责人进网站宣讲党的十九大精神 2019-09-03
  • 农民回答风水神,“勤劳的农民玩什么没有富起来”。(原创首发) 2019-09-02
  • 比赛8手机直播 极速11选5官网计划软件下载 7星彩预测杀号码 支付宝爱彩网 大赢家江西时时彩 平特一肖研究方法 923彩票 北京pk10七码计划网站 三肖中特创富网 时时彩人工计划 福彩浙江快乐12在线 竞彩比分玩法中奖 香港tm46特碼 生肖挂件 时时彩计划