判断图片加载完成,自适应iframe高度
在做RSS订阅的时候遇到这样一个问题:点击文章标题时,弹出文章的详细界面。本来打算直接用弹出div层来显示文章的内容,但是设置div的overflow:scroll滚动条不好看,还有就是在android、ios4及以下,会失效(这个可以使用iscroll.js来解决,)。最后改为iframe来显示文章内容。这里涉及到子页面和父页面的通信问题,不清楚可以看js之iframe子页面与父页面通信。
我在子页面获取到父页面传递过来的文章内容时,使用innerHTML将内容放入div中。代码如下:
<div id="article-area-id">
<div class="article-area" id="art">
</div>
</div>
<div id="close"></div>
<script src="js/vendor/jquery-1.10.2.min.js"></script>
<script>
var close_e = document.getElementById("close"),
e = document.getElementById("art");
function get(data){
e.innerHTML = data;
close_e.setAttribute("class","close");
resizeIframe();
}
function resizeIframe(){
parent.setIframe(document.body.offsetHeight);
}
close_e.addEventListener("click",function(){
parent.closeIframe();
close_e.removeAttribute("class");
}); </script>
在innerHTML后,iframe的高度并没有因为里面内容增加而改变,这里就需要iframe的高度自适应了。这里有一篇博文:Js动态获取iframe子页面的高度总结
但是我这里情况和这篇博文说的不同,因为我的iframe在设置内容时,已经加载了,并不会触发onload事件,所以我采用子页面重新获取自己的高度,然后传递给父页面,
父页面再来设置子页面iframe的高度。
function setIframe(count) {
var e = document.getElementById("ifm-id"),
clientWidth = document.body.clientWidth,
sty;
sty="height:"+(count+50)+"px;top:"+$(document).scrollTop()+"px;left:"+ (clientWidth>600?clientWidth*0.2+"px":clientWidth*0.1+"px");
e.setAttribute("style",sty);
e.scrolling="no";
//重置主页面高度,解决如果弹出文章高度超过页面高度时显示不完全。
if(count+$(document).scrollTop() > document.body.clientHeight){
document.body.height = count+$(document).scrollTop();
}
}
在上面代码处理后,就可以重置iframe的高度了,但是由于内容里面包含图片,如果在传递给父页面高度时,子页面还没有加载图片,就可能出现传给父页面的高度小于图片加载完成后的高度,导致子页面显示不完全。最开始,我想到一篇博文 《JS快速获取图片宽高的方法》,然后使用正则srcReg = /http:\/\/\S*\.(jpg|png|jpeg)\S*(?=")/g,将所有的图片全部获取然后获得宽高,为每个img设置width和height属性,这样就能获取iframe的正确高度而且还能根据设备的屏幕宽度将太大的图片缩小。但是由于我是从第三方抓取文章,请求图片会遇到304权限问题时使用正则将无法获取的图片隐藏,代码如下:
imgReg = /src=\S*\.(jpg|png|jpeg)\S*"/g;
des = description.replace(imgReg,function($1){
return $1+' onerror=\"this.style.display=\'none\';return true;\"';
})
如果图片没有权限,将会报异常,但是由于无法捕获图片的异常,就不能及时的终止获取图片宽高的请求事件,这回导致无法快速获取图片宽高,在多个图片的时候会有很大的延迟。这个问题纠结了好久,没有找到好的解决方案,记下来看看以后能不能看到别人的解决方法。
这里有一点疑问,留作下次试验,那就是img下载完成后,使用innerHTML将HTML代码写入文档后,图片是不是在缓存中读取,如果不是会导致额外的网络请求,这样肯定是不好的。最后采用的解决方法是在父页面获取滚动事件,判断子页面body高度和iframe高度是否一致,如果不一致,则跳转iframe高度。
$(window).scroll(function(){
$this = $(this);
if($(document).height() - $this.height() - $this.scrollTop() < 400){
$(".loadImg").addClass("load");
addContainer(10);
}
var $ifm = $("#ifm-id");
var ifmHeight = $(document.getElementById("ifm-id").contentWindow.document.body).height();
if($ifm.height() !== (ifmHeight+50)){
$ifm.height(ifmHeight + 50);
}
});
判断图片加载完成,自适应iframe高度的更多相关文章
- js判断图片加载完成后获取图片实际宽高
通常,我们会用jq的.width()/.height()方法获取图片的宽度/高度或者用js的.offsetwidth/.offsetheight方法来获取图片的宽度/高度,但这些方法在我们通过样式设置 ...
- JS判断图片加载完成方法
javascipt原生方法 选取指定ID的图片,通过onload指定回调方法,在图片加载完成后弹出“图片加载已完成”字样提示. <img id="pic1" src=&quo ...
- js判断图片加载完成
<!DOCTYPE> <html> <head> <meta http-equiv="Content-Type" content=&quo ...
- eayui js动态加载Datagrid,自适应宽度,高度
HTML: <div class="easyui-layout" style="min-height:100%;min-width:100%;"> ...
- javascrip笔记——图片加载
var t_img; // 定时器 var isLoad = true; // 控制变量 // 判断图片加载状况,加载完成后回调 isImgLoad(function(){ // 加载完成 }); / ...
- 移动web图片加载完获取img宽高
1.vue中 @load=function(){} 等待img加载完触发load函数 2.window.load=function(){var imgheight=$(".btnimg& ...
- 自适应文案提示框、无数据图片加载<IOS小组件>
非常感谢,帮助我的朋友们,谢谢你们. 该组件的编写仅仅用来不到4个小时,包括测试与修改bug.为他起名为AdaptivePromptDialogBox(就是自适应文案提示框): 呆毛地址:链接 < ...
- android 浏览器对图片加载高度渲染问题
今天在开发有道汉语词典移动版的时候遇到了一个很奇怪的问题. 在android设备上访问的时候,总是发现有底部背景色不能完全渲染出来的情况(有时候又是正常的,一会儿出现一会儿不出现,iphone设备也是 ...
- vue判断图片为空或者图片加载不成功时显示默认图片
纯css解决方案: <img src="broken.png" alt=""> img { position: relative; } img:af ...
随机推荐
- wordpress安装,创建配置文件无反应
wordpress安装时,点击“创建配置文件”无反应,可以手动创建wp-config.php, 打开wp-config-sample.php,配置相关信息,然后将文件改名为wp-config.php上 ...
- Android 使用Application类保存应用的全局数据
在实际应用我们经常需要对数据进行交互与保存,但Intent中默认的方法对传输数据是有类型限制的,当我们需要传输或保存一个复杂的泛型数据时,使用Application是一个很好的解决办法. 顾名思义,A ...
- 高性能jdbc封装工具 Apache Commons DbUtils 1.6(转载)
转载自原文地址:http://gao-xianglong.iteye.com/blog/2166444 前言 关于Apache的DbUtils中间件或许了解的人并不多,大部分开发人员在生成环境中更多的 ...
- Effective C++条款01: 视C++为一个语言联邦
一开始C++定义为:C with Classes. 如今的C++已经是一个多重范型编程语言,可以把C++视为有四个次语言组成的联邦语言. C.C++任然以C为基础.区块.语句.预处理.内置语言类型.数 ...
- uses-permission权限列表
android.permission.ACCESS_CHECKIN_PROPERTIES允许读写访问”properties”表在checkin数据库中,改值可以修改上传 android.permiss ...
- 深入理解Java内存模型(三)——顺序一致性
数据竞争与顺序一致性保证 当程序未正确同步时,就会存在数据竞争.java内存模型规范对数据竞争的定义如下: 在一个线程中写一个变量, 在另一个线程读同一个变量, 而且写和读没有通过同步来排序. 当代码 ...
- Mac下无法拷贝文件到移动硬盘
Mac下无法拷贝文件到移动硬盘? 是移动硬盘的文件格式的问题. Mac系统无法识别 NTFS 格式的文件. 将移动硬盘格式化为 exFAT 格式的. 别担心,exFAT 格式的硬盘在Windows下也 ...
- OpenMp并行提升时间为什么不是线性的?
最近在研究OpenMp,写了一段代码,如下: #include<time.h> #include<stdio.h> #include<stdlib.h> #incl ...
- MTK android flash配置
关于6573集成MCP nandflash的方法,driver_allinone 和Memory Customer Document pdf的说明里面漏了很多细节.在此补上. 1.首先确认flash型 ...
- leetcode:Isomorphic Strings
Isomorphic Strings Given two strings s and t, determine if they are isomorphic. Two strings are isom ...