千家信息网

js中resize事件怎么用

发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章主要介绍了js中resize事件怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、当浏览器窗口调整到新的高度或宽度时,会
千家信息网最后更新 2025年11月13日js中resize事件怎么用

这篇文章主要介绍了js中resize事件怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

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

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

实例

/** * Created by taozh on 2017/5/6. * taozh2982@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事件怎么用"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

事件 篇文章 价值 元素 兴趣 可以通过 同时 实例 宽度 更多 朋友 浏览器 特性 知识 程序 编带 行业 资讯 资讯频道 频道 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 ibmv3700怎样连接服务器 平顶山网络技术参考价格 广州致爱空间旅业网络技术有限公司靠谱么 如何应对大学网络安全威胁 网络安全股份 海阳软件开发哪家便宜 如何减少网络安全风险隐患 qq王者荣耀服务器哪个好 张掖网络安全生产 深圳市最近有哪些网络技术公司 综合管理服务器功能 天然化学产物数据库 河南普朗网络技术有限公司 企业网络安全培训学费 互联网科技板块的股票有哪些股 永丰软件开发专业 泄露出来的数据库怎么用 商务数据库实训 铜川市网络安全应急保障中心 exp条件导出数据库 云原生数据库部署 后端数据库的相应配置 数据库不用id自增长 电子发票邮箱连接服务器失败 网络安全和信息化哪个重要 衡阳游戏软件开发地址 网络安全文化宣传条幅 昭通互联网科技哪家强 设置数据库密码错误 北京博睿网络技术是哪家公司
0