1. David Wu首页
  2. WordPress
  3. WordPress安装教程

为iFrame添加动态载入提示优化用户体验

平常开发网站避免不了使用 iFrame 框架,但是当网络环境不好时 iFrame 内容一直都是直勾勾的加载,并且未加载完成之前还会强行占据一大片空白区域,体验很不友好!昨天在制作展示导航 wordpress 插件时,把这个问题也一并处理了,其中涉及到了这个 iFrame 动态载入效果,现在记录一下,顺便分享。

完整代码:

  1. <div style="float: left;width: 205px;font-size: 13px !important;line-height: 20px;" id="loading">
  2.     <img style="floa: left;height: 20px;width: 20px;" src="/loading.gif" />
  3.     联盟导航加载中,请稍后...
  4. </div>
  5. <iframe id="zgboke" onreadystatechange=stateChangeIE(this) onload=stateChangeFirefox(this) style="visibility: hidden;padding: 0px; width: 100%; height="0" src="http://zgboke.com/hutui.HTML" frameborder="no" border="0" marginwidth="0" marginheight="0" scrolling="no"></iframe>
  6. <script language="javascript">
  7.  function stateChangeIE(_frame)
  8.     {
  9.        if (_frame.readyState=="interactive")
  10.      {
  11.           var loader = document.getElementById("loading");
  12.           loader.innerHTML      = "";
  13.           loader.style.display = "none";
  14.           _frame.style.visibility = "visible";
  15.          }
  16.  }
  17.     function stateChangeFirefox(_frame)
  18.       {
  19.           var loader = document.getElementById("loading");
  20.           var f= document.getElementById("zgboke");
  21.           f.height="512";
  22.           loader.innerHTML      = "";
  23.           loader.style.display = "none";
  24.           _frame.style.visibility = "visible";
  25.  }
  26. </script>

以下是依葫芦画瓢的方法:

①、在 iframe 代码之前先插入一个 div 用于 iframe 载入前的显示,除了 id 需要一一对应,其他自行发挥即可。

②、将 iframe 的高度设为 0,并在原有 iframe 的基础上插入加载前和加载后的函数调用

  1. onreadystatechange=stateChangeIE(this)
  2. onload=stateChangeFirefox(this)

③、如代码的 8~28 行新增 2 个 js 函数即可,注意上下元素 ID 需要一 一对应;

④、其中 22 和 23 行禁止 iframe 未加载完成的空白占位,只有加载完成之后,才会将 iframe 的高度还原为 512。
Ps:代码涉及的元素 ID 对应及 CSS 调节,请自行搞定,就不赘述了。

原创文章,作者:DavidWu,如若转载,请注明出处:https://www.davidwu.net/archives/102681

服务项目 服务内容 收费标准(元)
开发定制 WordPress主题/插件开发定制 (以最终需求为准)
主题/插件汉化 汉化团队WordPress主题/插件,翻译率95% (以标的主题/插件的句子数量为准)
服务器环境配置 基于您现有服务器,搭建配置网站运行环境,结合我们多年来实战经验,可完美支持WordPress等PHP程序运行,并配置伪静态规则、优化目录权限等问题。服务器我们强烈推荐使用Linux系统。 100元/次
网站托管 若贵站目前尚无技术人员,无法完成服务器环境配置,可选择我们的网站托管服务,直接交付正常运行的WordPress站点,并且无需担心服务器的后续维护工作,一切都由我们来帮您完成。 标配套餐:1000元/年/站点 高配套餐:联系客服获取
网站加速优化 从服务器后端配置优化到WordPress数据库缓存、前端页面缓存、JS和CSS压缩合并,全方位优化网站加载速度,实现秒开。(此服务仅针对(云)服务器/VPS) 500元/次(仅站内优化200元/次)
主题配置 本站所有主题均支持,可快速实现,若有任何问题可以咨询客服解决,若您希望我们提供配置服务,可选购此服务。 英文主题安装 60元/次 汉化主题安装 30元/次
HTTPS配置 HTTPS已经不断普及,并且有着更高的安全性以及SEO上的优待。该服务收取的为服务费,SSL证书产生的费用请自行承担。 100元/次
网站搬家 迁移网站所有文件和数据库信息、网站相关配置的调整、以及迁移中的疑难问题故障排除。 标准收费:500元/次 若网站数据量大,需协商
网站运维 提供整站的运维服务,保证网站正常运行。包含:网站故障定位及排除、网站数据备份和恢复、网站攻击及木马等问题的处理等 标准收费:2000元/年 IP 5000以上需协商

发表评论

邮箱地址不会被公开。 必填项已用*标注