千家信息网

js中resize事件怎么用

发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章主要介绍了js中resize事件怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、当浏览器窗口调整到新的高度或宽度时,会
千家信息网最后更新 2025年02月03日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安全错误 数据库的锁怎样保障安全 安徽超频服务器成本价 达州软件开发哪家好 湖南创新网络技术服务信息中心 全国有多少学校有网络安全专业 电脑服务器管理显示设备未就绪 天津机架服务器 计算机网络技术为什么有ps 麻醉相关的数据库 攻击服务器的方式 中小学网络安全ppt课件 通勤人员会被移除数据库吗 锦州通显示服务器异常是怎么回事 互联网创新科技大赛项目策划书 嵌入式软件开发流程费用 免费香港服务器 oracle的数据库错误 厦门佳集悦网络技术有限公司 移动通信网络技术的发展 数据库自定义对象 Mesh数据库怎么用 软件开发关系图 泗阳自动化网络技术解决方案 通州区品牌软件开发优势 公安部网络安全保卫总队地址 亚马逊渠道服务器多少钱 怎么判断数据库是open 北京艾利艾互联网科技怎么样 怎么在服务器上跑r 贵州颐龙互联网科技有限公司 数据库原理课程建设思路
0