js中resize事件怎么解决
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,这篇文章主要讲解了"js中resize事件怎么解决",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"js中resize事件怎么解决"吧!1、当浏览器窗口调
千家信息网最后更新 2025年12月01日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记录修改数据库的用户
图形和数据库的关系
浪潮ps的服务器标志
数据库如何提取字段
软件开发非移交产品
mohist服务器特点
乌海网络技术联系方式
网络安全相关案例分析
数据库处理大数据
北京畅游悦动网络技术
进云服务器闪退
数据库实训电影院选择系统
娄烦易时空网络技术
数据库提取数据的过程
好评的分布式数据库分片
建立局域网服务器
教育行业关于网络安全政策
传奇数据库编辑器图解
极氪001软件开发商
mysql 跨数据库复制
关于网络安全的观后感怎么写视频
计算机网络技术基础课
排版软件开发兼职
数据库可以存储图片么
艾尔多战记在哪选择服务器
关于网络安全参考文献书
建立局域网服务器