iframe - 修改 iframe.src 而不进入历史对象

标签 iframe history back vimeo

我的网页中有一个 iframe。我通过 javascript 修改 src 属性,如下所示:

document.getElementById('myiframe').src = 'http://vimeo.com/videoid1';
document.getElementById('myiframe').src = 'http://vimeo.com/videoid2';
document.getElementById('myiframe').src = 'http://vimeo.com/videoid3';

但是,每次我执行此操作时,它都会记录到浏览器的历史记录中。因此,每次我在浏览器窗口中按回键时,iframe 内容都会从 videoid3 转到 videoid2 再到 videoid1。如果我再次按返回,整个页面都会返回。

我想使用 javascript 修改 iframe src,而不将条目记录到浏览器的历史记录中。因此,如果我单击浏览器后退按钮,整个页面都会返回而不更新 iframe。

我尝试做类似的事情:

document.getElementById('myiframe').contentWindow.location.replace('http://vimeo.com/videoid1');
document.getElementById('myiframe').contentWindow.location.replace('http://vimeo.com/videoid2');
document.getElementById('myiframe').contentWindow.location.replace('http://vimeo.com/videoid3');

虽然这使浏览器后退按钮的行为符合我想要的方式,但它破坏了 vimeo 视频中的某些内容。 Vimeo 要求您通过 iframe.src 而不是 contentWindow.location.replace() 更改网址。

因此,如何在不登录历史记录的情况下修改 iframe.src?

相关 这实际上是我正在探索解决主要问题的解决方案之一,我将其发布在这里History object back button with iframes

最佳答案

不更改src,只需用新的iframe替换旧的iframe吗?

const urls = [
  "http://bing.com",
  "http://google.com",
  "http://duckduckgo.com"
];

function next() {
  if(urls.length==0) return;
  const original = document.getElementsByTagName("iframe")[0];
  const newFrame = document.createElement("iframe");
  newFrame.src = urls.pop();
  original.parentNode.replaceChild(newFrame, original);
}

nextbtn.addEventListener("click", () => next());
iframe {
  width: 300px;
  height:300px;
}
<p>let's test some iframes</p>
<button id="nextbtn">next</button>
  <iframe />

没有历史记录。相同的功能。每个人都赢了。

关于iframe - 修改 iframe.src 而不进入历史对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14737365/

相关文章:

javascript - 为什么这个 JavaScript 广告只有在 &lt;iframe&gt; 中加载时才会被裁剪?

javascript - iframe 无法访问其父窗口属性

javascript - 将 Blob 设置为 iframe 的 "src"

jquery - 浏览器 "Back"按钮与 jQuery 动画页面

php - Ajax:将表单恢复为初始值

javascript - 将编辑器 html 保存到客户的计算机

JavaScript history.back() 有条件地

android - 如何在 Android 应用程序中保存历史记录?

android - 为什么关闭或按“后退”按钮时我的React Native Android应用程序崩溃?

javascript - 单击后退按钮时如何返回到之前的状态