一、什麼是 iframe
iframe 用於在頁面內顯示頁面,使用 <iframe> 會建立包含另外一個文件的內聯框架(即行內框架)
<iframe src="URL"></iframe>
二、iframe 的常用屬性1、width
定義 iframe 的寬度
2、height定義 iframe 的高度
3、name規定 iframe 的名稱
4、frameborder規定是否顯示邊框,值為 0(不顯示)和 1(顯示)
5、scrolling規定是否在 iframe 中顯示捲軸,值為 yes、no、auto
6、src設定 iframe 的地址(頁面/圖片)
7、srcdoc用來替換 iframe 中 html、body 裡的內容( IE 不支援)
8、sandbox對 iframe 進行內容限制,值為
allow-formsallow-same-originallow-scriptsallow-top-navigation...支援 IE10+
三、獲取 iframe 中的內容1、獲取 iframevar iframe = document.getElementById("iframe1");
2、iframe.contentWindow獲取iframe的window物件
var iwindow = iframe.contentWindow;
3、iframe.contentDocument
獲取iframe的document物件
var idoc = iwindow.document;
4、window.frames['name']
這種方法同樣可以獲取 window 物件
var iwindow = window.frames['name'];
四、在 iframe 中獲取父級內容1、window.parent
獲取上一級 window 物件( iframe 可以有多層使用)
2、window.top獲取最頂級容器的 window 物件,即開啟頁面時的文件
3、window.self返回自身 window 物件
五、iframe 的長輪詢長輪詢就是在 ajax 的 readyState = 4的時,再次執行原函式。
這裡使用 iframe 也是一樣,非同步建立 iframe,然後 reload
var iframeCon = docuemnt.querySelector('#container'), text; //傳遞的資訊 var iframe = document.createElement('iframe'), iframe.id = "frame", iframe.style = "display:none;", iframe.name="polling", iframe.src="target.html"; iframeCon.appendChild(iframe); iframe.onload= function(){ var iloc = iframe.contentWindow.location, idoc = iframe.contentDocument; setTimeout(function(){ text = idoc.getElementsByTagName('body')[0].textContent; console.log(text); iloc.reload(); //重新整理頁面,再次獲取資訊,並且會觸發onload函式 },2000); }
這樣就可以實現 ajax 長輪詢的效果。當然,這裡只是使用 reload 進行獲取,也可以新增 iframe 和刪除 iframe 的方式,進行傳送資訊,這些都是根據具體場景應用的。
另外在 iframe 中還可以實現非同步載入 js 檔案,不過,iframe 和主頁是共享連線池的,現在基本上都被 XHR 和 hard calllback 取締了
六、自適應 iframe - 廣告嵌入廣告通常與原文無關,如果直接在某個 div 下巢狀,會造成網頁佈局的紊亂,而且還需要引入額外的 css 和 js 檔案,極大降低了網頁的安全性。這些所有的弊端,都可以使用iframe進行解決。 可以將 iframe 理解為一個沙盒,裡面的內容能夠被 top window 完全控制,而且,主頁的 css 樣式不會入侵 iframe 裡面的樣式
預設情況下,iframe 會自帶捲軸,不會全屏,如果你想自適應iframe的話:
1、去掉捲軸<iframe src="./iframe1.html" id="iframe1" scrolling="no"></iframe>
2、設定 iframe 的高為 body 的高
var iwindow = iframe.contentWindow;var idoc = iwindow.document;iframe.height = idoc.body.offsetHeight;
另外,還可以新增其它的裝飾屬性:
七、iframe 的安全性1、防巢狀網頁iframe 享有 click 優先權,當有人在偽造的主頁中進行點選的話,如果點在 iframe 上,則會預設是在操作 iframe 的頁面。所以,釣魚網站就是使用這個技術,透過誘導使用者進行點選。為了防止網站被釣魚,可以使用 window.top 來防止你的網頁被 iframe,即限定你的網頁不能被巢狀在任何網頁內:
//iframe2.htmlif(window != window.top){ window.top.location.href = correctURL;}
2、X-Frame-Options
X-Frame-Options 是一個相應頭,主要是描述伺服器的網頁資源的 iframe 許可權,有3個選項:
DENY:當前頁面不能被巢狀 iframe 裡,即便是在相同域名的頁面中巢狀也不允許,也不允許網頁中有巢狀 iframeSAMEORIGIN:iframe 頁面的地址只能為同源域名下的頁面ALLOW-FROM:可以在指定的 origin url 的 iframe 中載入簡單例項:
X-Frame-Options: DENY拒絕任何iframe的巢狀請求X-Frame-Options: SAMEORIGIN只允許同源請求,例如網頁為 foo.com/123.php,則 foo.com 底下的所有網頁可以嵌入此網頁,但是 foo.com 以外的網頁不能嵌入X-Frame-Options: ALLOW-FROM http://s3131212.com只允許指定網頁的iframe請求,不過相容性較差Chrome不支援
X-Frame-Options 其實就是將前端 js 對 iframe 的把控交給伺服器來進行處理
//jsif(window != window.top){ window.top.location.href = window.location.href;}//等價於X-Frame-Options: DENY//jsif (top.location.hostname != window.location.hostname) { top.location.href =window.location.href;}//等價於X-Frame-Options: SAMEORIGIN
該屬性是對頁面的 iframe 進行一個主要限制,不過,涉及 iframe 的 header 可不止這一個,另外還有一個 Content Security Policy,同樣也可以對 iframe 進行限制
3、sandboxsandbox 就是用來給指定 iframe 設定一個沙盒模型限制 iframe 的更多許可權 sandbox 是 h5 的一個新屬性,IE10+支援 啟用方式就是使用 sandbox 屬性:
<iframe sandbox src=”...”></iframe>
這樣會對iframe頁面進行一系列的限制:
script 指令碼不能執行不能傳送 ajax 請求不能使用本地儲存,即 localStorage,cookie 等不能建立新的彈窗和 window不能傳送表單不能載入額外外掛比如 flash 等同時可以放寬一點許可權。在 sandbox 裡面進行一些簡單設定
<iframe sandbox=”allow-same-origin” src=”...”></iframe>
常用的配置項有:
可以透過在 sandbox 裡,新增允許進行的許可權.
<iframe sandbox=”allow-forms allow-same-origin allow-scripts” src=”...”></iframe>
這樣可以保證 js 指令碼的執行,但是禁止 iframe 裡的 javascript 執行 top.location = self.location
八、iframe 的侷限1、建立比一般的 DOM 元素慢了 1-2 個數量級iframe 的建立比其它包括 scripts 和 css 的 DOM 元素的建立慢了 1-2 個數量級,使用 iframe 的頁面一般不會包含太多 iframe,所以建立 DOM 節點所花費的時間不會佔很大的比重。但帶來一些其它的問題:onload 事件以及連線池(connection pool)
2、阻塞頁面載入及時觸發 window 的 onload 事件是非常重要的。onload 事件觸發使瀏覽器的 “忙” 指示器停止,告訴使用者當前網頁已經載入完畢。當 onload 事件載入延遲後,它給使用者的感覺就是這個網頁非常慢。
window 的 onload 事件需要在所有 iframe 載入完畢後(包含裡面的元素)才會觸發。在 Safari 和 Chrome 裡,透過 JavaScript 動態設定 iframe 的 SRC 可以避免這種阻塞情況
3、唯一的連線池瀏覽器只能開少量的連線到 web 伺服器。比較老的瀏覽器,包含 Internet Explorer 6 & 7 和 Firefox 2,只能對一個域名(hostname)同時開啟兩個連線。這個數量的限制在新版本的瀏覽器中有所提高。Safari 3+ 和 Opera 9+ 可同時對一個域名開啟 4 個連線,Chrome 1+, IE 8 以及 Firefox 3 可以同時開啟 6 個
絕大部分瀏覽器,主頁面和其中的 iframe 是共享這些連線的。這意味著 iframe 在載入資源時可能用光了所有的可用連線,從而阻塞了主頁面資源的載入。如果 iframe 中的內容比主頁面的內容更重要,這當然是很好的。但通常情況下,iframe 裡的內容是沒有主頁面的內容重要的。這時 iframe 中用光了可用的連線就是不值得的了。一種解決辦法是,在主頁面上重要的元素載入完畢後,再動態設定 iframe 的 SRC。
4、不利於 SEO搜尋引擎的檢索程式無法解讀 iframe。另外,iframe 本身不是動態語言,樣式和指令碼都需要額外匯入。綜上,iframe 應謹慎使用。