ifram在bootstrap modal中演进的自适应迭代至1.0版本

2024-05-06 23:08

本文主要是介绍ifram在bootstrap modal中演进的自适应迭代至1.0版本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 需引入layer.js loading加载遮罩层会被使用到
  • 0.1版本显示页面但大小会随机变化。
  • 0.2版本内嵌页面与主页面都要js控制,页面有时候不能显示。
  • 1.0版本内嵌页面无需写额外js,只需主页面js控制,代码实现了自适应,且显示正常。
  • ifram可能会在加载关闭时内存泄漏,此处显式调用ifram clear防止内存泄漏
var Tools = (function ($) {var IframeFirstClear = function (iframedom) {var ifd = $(iframedom);if (ifd.length > 0) {ifd[0].contentWindow.document.write(''); //清空iframe的内容ifd[0].contentWindow.close(); //避免iframe内存泄漏ifd.remove(); //删除iframeconsole.log('iframe-clean');}};return {IFC: IframeFirstClear};})(jQuery);Tools.IFC("#EPageIframe");
  • 配合bootstrap modal引入ifram自定义插件
 (function ($) {$.extend({modelshowiframe: function (options) {//面向对象的写法new modeladapt(this, options);}})var modeladapt = function (ele, options) {if (options == null)alert("arg error")this.element = ele;this.options = {labledom: "#EPageIframeModalLabel",labletext: "",iframedom: "#EPageIframe",iframesrc: "",modeldom: "#EPageIframeModal"};this.options = $.extend({}, this.options, options);this.init();}//初始化对象modeladapt.prototype = {init: function () {//初始化this.ModelIframe();},ModelIframe: function () {var that = this;$(that.options.labledom).text(that.options.labletext);$(that.options.modeldom).modal({ show: true, backdrop: "static" });var index = layer.load(0, { shade: false }); //loading层var iframe = document.createElement("iframe");iframe.id = "EPageIframe";iframe.src = that.options.iframesrc;iframe.style.width = "100%";iframe.setAttribute("frameborder", 0);iframe.setAttribute("scrolling", "no");document.getElementById("EPageIframeDiv").appendChild(iframe);console.log('iframe-ready');if (iframe.attachEvent) {$(iframe).load(function () {setTimeout(function () {var heightiframe = iframe.contentWindow.document.documentElement.scrollHeight;iframe.height = heightiframe;console.log('iframe-load-ok-A-' + heightiframe);layer.close(index); //iframe加载完毕  }, 100);});} else {$(iframe).load(function () {setTimeout(function () {var heightiframe = iframe.contentDocument.body.scrollHeight;iframe.height = heightiframe;console.log('iframe-load-ok-B-' + heightiframe);layer.close(index); //iframe加载完毕  }, 100);});}}}})(window.jQuery);</script>
  • bootstrap modal代码
<div class="modal fade" id="EPageIframeModal"><div class="modal-dialog" ><div class="modal-content"><div class="modal-header"><button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button><h4 class="modal-title" id="EPageIframeModalLabel">消息</h4></div><div class="modal-body" id="EPageIframeDiv" style="clear:both;"></div></div></div>
</div>
  • 使用指南,主页面使用代码
  • labletext 头部名字
  • iframesrc 嵌套页面地址
$.modelshowiframe({labletext: "测试弹出页面",iframesrc: "/AAA/show/" + Id});

这篇关于ifram在bootstrap modal中演进的自适应迭代至1.0版本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/965642

相关文章

C++迭代器失效的避坑指南

《C++迭代器失效的避坑指南》在C++中,迭代器(iterator)是一种类似指针的对象,用于遍历STL容器(如vector、list、map等),迭代器失效是指在对容器进行某些操作后... 目录1. 什么是迭代器失效?2. 哪些操作会导致迭代器失效?2.1 vector 的插入操作(push_back,

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

查看MySQL数据库版本的四种方法

《查看MySQL数据库版本的四种方法》查看MySQL数据库的版本信息可以通过多种方法实现,包括使用命令行工具、SQL查询语句和图形化管理工具等,以下是详细的步骤和示例代码,需要的朋友可以参考下... 目录方法一:使用命令行工具1. 使用 mysql 命令示例:方法二:使用 mysqladmin 命令示例:方

全解析CSS Grid 的 auto-fill 和 auto-fit 内容自适应

《全解析CSSGrid的auto-fill和auto-fit内容自适应》:本文主要介绍了全解析CSSGrid的auto-fill和auto-fit内容自适应的相关资料,详细内容请阅读本文,希望能对你有所帮助... css  Grid 的 auto-fill 和 auto-fit/* 父元素 */.gri

Java版本不兼容问题详细解决方案步骤

《Java版本不兼容问题详细解决方案步骤》:本文主要介绍Java版本不兼容问题解决的相关资料,详细分析了问题原因,并提供了解决方案,包括统一JDK版本、修改项目配置和清理旧版本残留等步骤,需要的朋... 目录错误原因分析解决方案步骤第一步:统一 JDK 版本第二步:修改项目配置第三步:清理旧版本残留兼容性对

Linux搭建单机MySQL8.0.26版本的操作方法

《Linux搭建单机MySQL8.0.26版本的操作方法》:本文主要介绍Linux搭建单机MySQL8.0.26版本的操作方法,本文通过图文并茂的形式给大家讲解的非常详细,感兴趣的朋友一起看看吧... 目录概述环境信息数据库服务安装步骤下载前置依赖服务下载方式一:进入官网下载,并上传到宿主机中,适合离线环境

Python 迭代器和生成器概念及场景分析

《Python迭代器和生成器概念及场景分析》yield是Python中实现惰性计算和协程的核心工具,结合send()、throw()、close()等方法,能够构建高效、灵活的数据流和控制流模型,这... 目录迭代器的介绍自定义迭代器省略的迭代器生产器的介绍yield的普通用法yield的高级用法yidle

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa