千家信息网

js中resize事件怎么解决

发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,这篇文章主要讲解了"js中resize事件怎么解决",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"js中resize事件怎么解决"吧!1、当浏览器窗口调
千家信息网最后更新 2025年02月23日js中resize事件怎么解决

这篇文章主要讲解了"js中resize事件怎么解决",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"js中resize事件怎么解决"吧!

1、当浏览器窗口调整到新的高度或宽度时,会触发resize事件。

2、在window(窗口)上触发,因此可以通过JavaScript或元素中的onresize特性来指定事件处理程序。

实例

/** * Created by taozh on 2017/5/6. * taozh1982@gmail.com */var EleResize = {    _handleResize: function (e) {        var ele = e.target || e.srcElement;        var trigger = ele.__resizeTrigger__;        if (trigger) {            var handlers = trigger.__z_resizeListeners;            if (handlers) {                var size = handlers.length;                for (var i = 0; i < size; i++) {                    var h = handlers[i];                    var handler = h.handler;                    var context = h.context;                    handler.apply(context, [e]);                }            }        }    },    _removeHandler: function (ele, handler, context) {        var handlers = ele.__z_resizeListeners;        if (handlers) {            var size = handlers.length;            for (var i = 0; i < size; i++) {                var h = handlers[i];                if (h.handler === handler && h.context === context) {                    handlers.splice(i, 1);                    return;                }            }        }    },    _createResizeTrigger: function (ele) {        var obj = document.createElement('object');        obj.setAttribute('style',            'display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden;opacity: 0; pointer-events: none; z-index: -1;');        obj.onload = EleResize._handleObjectLoad;        obj.type = 'text/html';        ele.appendChild(obj);        obj.data = 'about:blank';        return obj;    },    _handleObjectLoad: function (evt) {        this.contentDocument.defaultView.__resizeTrigger__ = this.__resizeElement__;        this.contentDocument.defaultView.addEventListener('resize', EleResize._handleResize);    }};if (document.attachEvent) {//ie9-10    EleResize.on = function (ele, handler, context) {        var handlers = ele.__z_resizeListeners;        if (!handlers) {            handlers = [];            ele.__z_resizeListeners = handlers;            ele.__resizeTrigger__ = ele;            ele.attachEvent('onresize', EleResize._handleResize);        }        handlers.push({            handler: handler,            context: context        });    };    EleResize.off = function (ele, handler, context) {        var handlers = ele.__z_resizeListeners;        if (handlers) {            EleResize._removeHandler(ele, handler, context);            if (handlers.length === 0) {                ele.detachEvent('onresize', EleResize._handleResize);                delete  ele.__z_resizeListeners;            }        }    }} else {    EleResize.on = function (ele, handler, context) {        var handlers = ele.__z_resizeListeners;        if (!handlers) {            handlers = [];            ele.__z_resizeListeners = handlers;             if (getComputedStyle(ele, null).position === 'static') {                ele.style.position = 'relative';            }            var obj = EleResize._createResizeTrigger(ele);            ele.__resizeTrigger__ = obj;            obj.__resizeElement__ = ele;        }        handlers.push({            handler: handler,            context: context        });    };    EleResize.off = function (ele, handler, context) {        var handlers = ele.__z_resizeListeners;        if (handlers) {            EleResize._removeHandler(ele, handler, context);            if (handlers.length === 0) {                var trigger = ele.__resizeTrigger__;                if (trigger) {                    trigger.contentDocument.defaultView.removeEventListener('resize', EleResize._handleResize);                    ele.removeChild(trigger);                    delete ele.__resizeTrigger__;                }                delete  ele.__z_resizeListeners;            }        }    }}

感谢各位的阅读,以上就是"js中resize事件怎么解决"的内容了,经过本文的学习后,相信大家对js中resize事件怎么解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

事件 学习 内容 元素 可以通过 实例 宽度 就是 思路 情况 文章 更多 浏览器 特性 知识 知识点 程序 篇文章 跟着 问题 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 香肠派对哪个服务器更简单 电力信息网络安全拓扑图 网络技术该入什么科目 河南信道捷网络技术有限公司 sql导出全部数据库 河南掌上登记扫码出现服务器异常 网络安全风险防范意识 芯片设计vs嵌入式软件开发 在海航软件开发上班时间 西安聚点网络技术有限公司 方舟服务器创建手游 微信小程序配置服务器 灵魂服务器 点石成金实用技术数据库 珠海来来网络技术有限公司 西城区推广网络技术诚信服务 数据库设计的核心是阶段 非法集资公司网络技术人员 数据库两张表字段组合查询 手机能访问的web服务器 北京特定软件开发现价 乐学邦网络技术有限公司 学校网络安全自查自评制度 软件开发工程师左传波 2021国家网络安全风险 计算机软件开发图书 用友财务软件的数据库是什么 查询行云数据库剩余空间 苹果手机缴费软件连接服务器失败 showdoc数据库在
0