[英]Reload iframe only when iframe contents are new?
簡潔版本:
每當iframe
的內容是新的時,具有iframe
指向同一服務器上另一個HTML文件的HTML文件如何自動重新加載該iframe
?
語境:
我正在使用HTML / JavaScript文件來查看Python程序中的新指令。 有新的說明要看時,Python程序將重寫一個簡單的HTML文件。
因此,我的簡單解決方案是使用Javascript強制每秒重新加載iframe
src。
但是,這會在每次加載iframe
時(大多數情況下不是新信息)都會刷新內容。
相反,我希望HTML文件僅在新文件時才強制重新加載iframe
src。 這可能嗎?
您可以使用AJAX請求來檢查iframe
是否已更改。
var value;
(function check() {
var xhr = new XMLHttpRequest();
xhr.open('GET', '/url/toIframe'); // change this to the correct URL
xhr.addEventListener('load', function() {
if(value === undefined) {
value = this.responseText;
} else if(value != this.responseText) {
value = this.responseText;
// refresh iframe!
}
setTimeout(check, 1000); // check again in another second
});
xhr.send();
})();
這向服務器發出請求,以查看內容是否已更改。 在請求結束和下一次檢查開始之間有一秒鍾的時間。 (目前,如果服務器出現故障,將沒有錯誤處理。)
僅供參考,如果服務器發送了Last-Modified
標頭,則實際上您可以發出HEAD請求,只需檢查該標頭即可。 如果您不知道我在說什么,就不用擔心。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.