首页 > 其他分享 >解决页面刷新后firefox浏览器中iframe内容不更新的问题

解决页面刷新后firefox浏览器中iframe内容不更新的问题

时间:2024-06-21 10:33:47浏览次数:26  
标签:嵌入 网页 iframe firefox allow 浏览器 const

最近遇到了一个问题:使用firefox浏览切换2层iframe下的某个页面后iframe内容未更新,Chrome和Edge浏览器并无这个问题。在这个项目中,最外层的iframe用于隐藏url,里层的iframe用于给不同参数的url提供一个统一地址以便于权限路由等控制。  由于项目比较复杂,用简单的代码很难去复现这个bug。这里只能贴出解决办法。

查阅资料后发现是firefox浏览器的iframe缓存引起的。试用了以下几个办法

禁止页面缓存

<?php
header("Cache-Control: no-cache, no-store, must-revalidate"); // HTTP 1.1.
header("Pragma: no-cache"); // HTTP 1.0.
header("Expires: 0"); // Proxies.

?>

问题依然存在

在url参数中添加动态参数

<iframe src="url?ts=<?= time();?>"></iframe>

均未能解决问题

重新加载url

<script>
    const iframe = $('iframe')[0];
    const url = "{{ url('page') . '?pt=' . $pt }}";
    // console.log(iframe.contentDocument, iframe.contentWindow)
    if (/firefox/i.test(navigator.userAgent)) {
        iframe.src = url;
        // iframe.contentWindow.location.reload();//此种方法不生效
    }
});
</script>

 此种方法终于生效

 

iframe的使用详解

本部分内容来源自  https://mp.weixin.qq.com/s?__biz=MjM5MDA2MTI1MA==&mid=2649103699&idx=4&sn=8f51011680bb44e363ff6f3d696c2df3&chksm=be583afe892fb3e8d8b93a72c512ba667708e50c302bcee8431ad92a18ad6a8002c5af0925b0&scene=27

 <iframe>标签用于在网页里面嵌入其他网页。  <iframe>标签生成一个指定区域,在该区域中嵌入其他网页。它是一个容器元素,如果浏览器不支持<iframe>,就会显示内部的子元素。    <iframe>的属性如下
  •   allowfullscreen:允许嵌入的网页全屏显示,需要全屏 API 的支持,请参考相关的 JavaScript 教程。
  •   frameborder:是否绘制边框,0为不绘制,1为绘制(默认值)。建议尽量少用这个属性,而是在 CSS 里面设置样式。
  •   src:嵌入的网页的 URL。
  •   width:显示区域的宽度。
  •   height:显示区域的高度。
  •   sandbox:设置嵌入的网页的权限,详见下文。
  •   importance:浏览器下载嵌入的网页的优先级,可以设置三个值。high表示高优先级,low表示低优先级,auto表示由浏览器自行决定。
  •   name:内嵌窗口的名称,可以用于<a>、<form>、<base>的target属性。
  •   referrerpolicy:请求嵌入网页时,HTTP 请求的Referer字段的设置。参见<a>标签的介绍。
  sandbox 属性   嵌入的网页默认具有正常权限,比如执行脚本、提交表单、弹出窗口等。如果嵌入的网页是其他网站的页面,你不了解对方会执行什么操作,因此就存在安全风险。为了限制<iframe>的风险,HTML 提供了   sandbox属性,允许设置嵌入的网页的权限,等同于提供了一个隔离层,即“沙箱”。   sandbox属性可以设置具体的值,表示逐项打开限制。未设置某一项,就表示不具有该权限。
  •   allow-forms:允许提交表单。
  •   allow-modals:允许提示框,即允许执行window.alert()等会产生弹出提示框的 JavaScript 方法。
  •   allow-popups:允许嵌入的网页使用window.open()方法弹出窗口。
  •   allow-popups-to-escape-sandbox:允许弹出窗口不受沙箱的限制。
  •   allow-orientation-lock:允许嵌入的网页用脚本锁定屏幕的方向,即横屏或竖屏。
  •   allow-pointer-lock:允许嵌入的网页使用 Pointer Lock API,锁定鼠标的移动。
  •   allow-presentation:允许嵌入的网页使用 Presentation API。
  •   allow-same-origin:不打开该项限制,将使得所有加载的网页都视为跨域。
  •   allow-scripts:允许嵌入的网页运行脚本(但不创建弹出窗口)。
  •   allow-storage-access-by-user-activation:允许在用户激动的情况下,嵌入的网页通过 Storage Access API 访问父窗口的储存。
  •   allow-top-navigation:允许嵌入的网页对顶级窗口进行导航。
  •   allow-top-navigation-by-user-activation:允许嵌入的网页对顶级窗口进行导航,但必须由用户激活。
  •   allow-downloads-without-user-activation:允许在没有用户激活的情况下,嵌入的网页启动下载。
  注意,不要同时设置allow-scripts和allow-same-origin属性,这将使得嵌入的网页可以改变或删除sandbox属性。     loading 属性   <iframe>指定的网页会立即加载,有时这不是希望的行为。<iframe>滚动进入视口以后再加载,这样会比较节省带宽。   loading属性可以触发<iframe>网页的懒加载。该属性可以取以下三个值。
  •   auto:浏览器的默认行为,与不使用loading属性效果相同。
  •   lazy:<iframe>的懒加载,即将滚动进入视口时开始加载。
  •   eager:立即加载资源,无论在页面上的位置如何。
  有一点需要注意,如果<iframe>是隐藏的,则loading属性无效,将会立即加载。只要满足以下任一个条件,Chrome 浏览器就会认为<iframe>是隐藏的。   <iframe>的宽度和高度为4像素或更小。  样式设为display: none或visibility: hidden。  使用定位坐标为负X或负Y,将<iframe>放置在屏幕外。

 

iframe父子操作

父页面

<style>
  iframe {
    display: block;
    width: 100%;
    height: 35vh;
  }
</style>
<script>
  document.addEventListener("DOMContentLoaded", function () {
    const inWindow = document.getElementsByName("same")[0].contentWindow;
    const inDocument = document.getElementsByName("same")[0].contentDocument;
    console.log(inWindow, inDocument);

    const innerWindow = window.frames["same"].window;
    const innerDocument = window.frames["same"].document;
    console.log(innerWindow, innerDocument);

    const iframe = document.getElementById("same");
    iframe.onload = function () {
      const iframeDoc = iframe.contentDocument || iframe.contentWindow.document;
      const elem = iframeDoc.getElementById("child");
      setTimeout(() => {
        elem.innerHTML = 1;
      }, 2000);
    };
  });
</script>
<div id="parent">11</div>
同域
<iframe id="same" name="same" frameborder="no" scrolling="auto" src="./iframe-inner.html"></iframe>
不同域
<iframe id="cross" name="cross" frameborder="no" scrolling="auto" src="https://www.baidu.com/img/PCtm_d9c8750bed0b3c7d089fa7d55720d6cf.png"></iframe>

 子页面

<div>inner page</div>
<div id="child">0</div>
<script>
  const elem = window.parent.document.getElementById("parent");
  setTimeout(() => {
    elem.innerHTML = "22";
  }, 5000);
</script>

 

标签:嵌入,网页,iframe,firefox,allow,浏览器,const
From: https://www.cnblogs.com/caroline2016/p/18259919

相关文章

  • Chrome谷歌浏览器如何设置,才能正常使用?
    Chrome浏览器,也被称为谷歌浏览器,由于简洁的界面设计,极快的响应速度,强大的插件商店,在全球浏览器市场份额中一直都处于遥遥领先的地位。但是因为2010年谷歌宣布退出中国,国内不能再使用谷歌的服务,所以在国内需要设置一下才能正常的使用,如何设置呢?今天教给大家。首先下载Chrome浏......
  • 深入分析Edge浏览器的插件兼容性:拥抱开放网络生态
    微软Edge浏览器自推出以来,一直在积极扩展其插件生态系统,以提高用户的浏览体验。插件兼容性是Edge浏览器用户体验的关键因素之一,它决定了用户能够无缝使用多少现有的Chrome扩展。本文将深入探讨Edge浏览器的插件兼容性,分析其优势、挑战以及未来的发展方向。1.插件兼容性的......
  • 深入解析微软Edge浏览器:探索其功能与应用
    微软Edge浏览器是微软公司推出的一款现代化网页浏览器,旨在为用户提供快速、安全和高效的上网体验。本文将全面解析微软Edge浏览器,从其历史背景、核心功能、性能表现、安全特性到实际应用场景,带领读者深入了解这款浏览器的优势和使用技巧。一、Edge浏览器的历史背景1.1Edge的......
  • SpringBoot+Selenium模拟用户操作浏览器
    SeleniumSelenium是一个用于Web应用程序自动化测试的开源工具套件。它主要用于以下目的:浏览器自动化:Selenium能够模拟真实用户在不同浏览器(如Chrome、Firefox、IE/Edge等)中的交互行为,通过编程方式控制浏览器执行一系列操作,例如点击按钮、填写表单、导航页面等。兼容性测试:通过......
  • 借助浏览器实现一个录屏插件?
    说在前面......
  • 浏览器http相关问题
    文章目录浏览器http相关问题1.http常用状态码2.Cookiesessionlocalstorage区别3.http和https的区别浏览器http相关问题1.http常用状态码HTTP状态码(英语:HTTPStatusCode)用来表示请求的结果,状态码被分为五大类:100-199信息,服务器收到请求,需要请求者继续执行......
  • Python文件嵌入html(vue)中,在浏览器中跑起来
    近期有个需求,之前项目是用python写的,需要包一层html,在浏览器中跑起来。推荐框架PyScript  https://pyscript.net/ 文档中有一些在线的example 在本地试了试<!doctypehtml><html><head><!--Recommendedmetatags--><metacharset="UTF-8"><metaname......
  • 微软Edge浏览器的主要功能
    引言微软Edge浏览器是Windows10操作系统附带的默认网页浏览器,它取代了InternetExplorer成为微软推荐的浏览器选择。Edge浏览器不仅提供了现代化的界面设计,还引入了一系列创新功能,以提高用户的浏览体验、安全性和隐私保护。本文将详细介绍Edge浏览器的主要功能。性能和速......
  • 微软Edge浏览器功能、特点与使用技巧
    微软Edge浏览器自从发布以来,已经成为了一个备受关注的现代浏览器。基于Chromium内核,Edge不仅继承了Chrome的优秀性能,还融入了微软自己的特色功能和服务。本文将全面解析Edge浏览器,包括其主要功能、独特特点以及一些实用的使用技巧,帮助你更好地利用这款浏览器。一、Edge浏......
  • 【应用介绍】微软Edge浏览器全解析
    微软Edge浏览器自从发布以来,已经成为了一个备受关注的现代浏览器。基于Chromium内核,Edge不仅继承了Chrome的优秀性能,还融入了微软自己的特色功能和服务。本文将全面解析Edge浏览器,包括其主要功能、独特特点以及一些实用的使用技巧,帮助你更好地利用这款浏览器。一、Edge浏......