• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    iframe,我們來談一談_html/css

    來源:懂視網 責編:小采 時間:2020-11-27 16:37:32
    文檔

    iframe,我們來談一談_html/css

    iframe,我們來談一談_html/css_WEB-ITnose:某大咖說: iframe是能耗最高的一個元素,請盡量減少使用 某大牛說: iframe安全性太差,請盡量減少使用 … wtf, 你們知不知道你們這樣澆滅了多少孩紙學習iframe的熱情和決心。 雖然,你們這樣說的我竟無法反駁,但是iframe強大功能是不容忽視的
    推薦度:
    導讀iframe,我們來談一談_html/css_WEB-ITnose:某大咖說: iframe是能耗最高的一個元素,請盡量減少使用 某大牛說: iframe安全性太差,請盡量減少使用 … wtf, 你們知不知道你們這樣澆滅了多少孩紙學習iframe的熱情和決心。 雖然,你們這樣說的我竟無法反駁,但是iframe強大功能是不容忽視的

    某大咖說: “iframe是能耗最高的一個元素,請盡量減少使用”

    某大牛說: “iframe安全性太差,請盡量減少使用”

    wtf, 你們知不知道你們這樣澆滅了多少孩紙學習iframe的熱情和決心。 雖然,你們這樣說的我竟無法反駁,但是iframe強大功能是不容忽視的。 可以看看各大郵箱網站是否還在使用iframe,查查知乎 iframe . iframe不死,我心不滅?,F在給大家安利一下iframe.

    iframe基本內涵

    通常我們使用iframe直接直接在頁面嵌套iframe標簽指定src就可以了。

     

    但是,有追求的我們,并不是想要這么low的iframe. 我們來看看在iframe中還可以設置些什么屬性

    iframe常用屬性:1.frameborder:是否顯示邊框,1(yes),0(no)2.height:框架作為一個普通元素的高度,建議在使用css設置。3.width:框架作為一個普通元素的寬度,建議使用css設置。4.name:框架的名稱,window.frames[name]時專用的屬性。5.scrolling:框架的是否滾動。yes,no,auto。6.src:內框架的地址,可以使頁面地址,也可以是圖片的地址。7.srcdoc , 用來替代原來HTML body里面的內容。但是IE不支持, 不過也沒什么卵用8.sandbox: 對iframe進行一些列限制,IE10+支持

    上面一些tag,會在下文進行穿插說明,單個不好說。

    我們通常使用iframe最基本的特性,就是能自由操作iframe和父框架的內容(DOM). 但前提條件是同域. 如果跨域頂多只能實現頁面跳轉 window.location.href .

    那什么是同域/ 什么是跨域呢?

    就是判斷你的url首部是否一樣,下面會有講解,這里只是提及。

    同域不同域的問題:

    A:B:

    使用A時,因為同域,父頁面可以對子頁面進行改寫,反之亦然。

    使用B時,不同域,父頁面沒有權限改動子頁面,但可以實現頁面的跳轉

    這里,我們先從簡單的開始,當主頁面和iframe同域時,我們可以 干 些什么。

    獲取iframe里的內容

    主要的兩個API就是contentWindow,和contentDocument

    iframe.contentWindow, 獲取iframe的window對象

    iframe.contentDocument, 獲取iframe的document對象

    這兩個API只是DOM節點提供的方式(即getELement系列對象)

     var iframe = document.getElementById("iframe1"); var iwindow = iframe.contentWindow; var idoc = iwindow.document; console.log("window",iwindow);//獲取iframe的window對象 console.log("document",idoc); //獲取iframe的document console.log("html",idoc.documentElement);//獲取iframe的html console.log("head",idoc.head); //獲取head console.log("body",idoc.body); //獲取body

    實際情況如:

    另外更簡單的方式是,結合Name屬性,通過window提供的frames獲取.

     

    Your browser does not support iframes.

    其實window.frames[‘ifr1′]返回的就是window對象,即

    window.frames['ifr1']===window

    這里就看你想用哪一種方式獲取window對象,兩者都行,不過本人更傾向于第二種使用frames[xxx].因為,字母少啊喂~ 然后,你就可以操控iframe里面的DOM內容。

    在iframe中獲取父級內容

    同理,在同域下,父頁面可以獲取子iframe的內容,那么子iframe同樣也能操作父頁面內容。在iframe中,可以通過在window上掛載的幾個API進行獲取.

    window.parent 獲取上一級的window對象,如果還是iframe則是該iframe的window對象window.top 獲取最頂級容器的window對象,即,就是你打開頁面的文檔window.self 返回自身window的引用??梢岳斫?window===window.self(腦殘)

    如圖: 來個栗子~

    ok, 獲取了之后,我們就可以進行相關操作了。 在同域的iframe中,我們可以巧妙的使用iframe的黑科技來實現一些trick.

    iframe的輪詢

    話說在很久很久以前,我們實現異步發送請求是使用iframe實現的~!

    怎么可能!!!

    真的史料為證(自行google), 那時候為了不跳轉頁面,提交表單時是使用iframe提交的?,F在,前端發展尼瑪真快,websocket,SSE,ajax等,逆天skill的出現,顛覆了iframe, 現在基本上只能活在IE8,9的瀏覽器內了。 但是,寶寶以為這樣就可以不用了解iframe了,而現實就是這么殘酷,我們目前還需要兼容IE8+。所以,iframe 實現長輪詢和長連接的trick 我們還是需要涉獵滴。

    iframe長輪詢

    如果寫過ajax的童鞋,應該知道,長輪詢就是在ajax的readyState = 4的時,再次執行原函數即可。 這里使用iframe也是一樣,異步創建iframe,然后reload, 和后臺協商好, 看后臺哥哥們將返回的信息放在,然后獲取里面信息即可. 這里是直接放在body里.

    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); iloca.reload(); //刷新頁面,再次獲取信息,并且會觸發onload函數 },2000); }

    這樣就可以實現ajax的長輪詢的效果。 當然,這里只是使用reload進行獲取,你也可以添加iframe和刪除iframe的方式,進行發送信息,這些都是根據具體場景應用的。另外在iframe中還可以實現異步加載js文件,不過,iframe和主頁是共享連接池的,所以還是很蛋疼的,現在基本上都被XHR和hard calllback取締了,這里也不過多介紹了。

    自適應iframe之蜜汁廣告

    網頁為了賺錢,引入廣告是很正常的事了。通常的做法就是使用iframe,引入廣告地址就可以了,然后根據廣告內容設置相應的顯示框。但是,為什么是使用iframe來進行設置,而不是在某個div下嵌套就行了呢?

    要知道,廣告是與原文無關的,這樣硬編碼進去,會造成網頁布局的紊亂,而且,這樣勢必需要引入額外的css和js文件,極大的降低了網頁的安全性。 這些所有的弊端,都可以使用iframe進行解決。

    我們通??梢詫frame理解為一個沙盒,里面的內容能夠被top window 完全控制,而且,主頁的css樣式是不會入侵iframe里面的樣式,這些都給iframe的廣告命運埋下伏筆??梢钥匆幌赂鞔笳军c是否都在某處放了些廣告,以維持生計比如: W3School

    但,默認情況下,iframe是不適合做展示信息的,所以我們需要對其進行decorate.

    自適應iframe

    默認情況下,iframe會自帶滾動條,不會全屏.如果你想自適應iframe的話:第一步:去掉滾動條

    第二步,設置iframe的高為body的高

    var iwindow = iframe.contentWindow;var idoc = iwindow.document;iframe.height = idoc.body.offsetHeight;

    另外,還可以添加其它的裝飾屬性:

    屬性 效果
    allowtransparency true or false是否允許iframe設置為透明,默認為false
    allowfullscreen true or false是否允許iframe全屏,默認為false

    看個例子:

    你可以直接寫在內聯里面,也可以在css里面定義,不過對于廣告iframe來說,樣式寫在屬性中,是best pratice.

    iframe安全性探索

    iframe出現安全性有兩個方面,一個是你的網頁被別人iframe,一個是你iframe別人的網頁。 當你的網頁被別人iframe時,比較蛋疼的是被釣魚網站利用,然后victim+s留言逼逼你。真.簡直了。 所以為了防止頁面被一些 不法分子 利用,我們需要做好安全性措施。

    防嵌套網頁

    比如,最出名的 clickhacking 就是使用iframe來 攔截click事件。因為iframe享有著click的最優先權,當有人在偽造的主頁中進行點擊的話,如果點在iframe上,則會默認是在操作iframe的頁面。 所以,釣魚網站就是使用這個技術,通過誘導用戶進行點擊,比如,設計一個”妹妹寂寞了”等之類的網頁,誘導用戶點擊,但實際結果,你看到的不是”妹妹”,而是被惡意微博吸粉。

    所以,為了防止網站被釣魚,可以使用window.top來防止你的網頁被iframe.

    //iframe2.htmlif(window != window.top){ window.top.location.href = correctURL;}

    這段代碼的主要用途是限定你的網頁不能嵌套在任意網頁內。如果你想引用同域的框架的話,可以判斷域名。

    if (top.location.host != window.location.host) {  top.location.href = window.location.href;}

    當然,如果你網頁不同域名的話,上述就會報錯。

    所以,這里可以使用try…catch…進行錯誤捕獲。如果發生錯誤,則說明不同域,表示你的頁面被盜用了??赡苡行g覽器這樣寫是不會報錯,所以需要降級處理。

    這時候再進行跳轉即可.

    try{  top.location.hostname; //檢測是否出錯  //如果沒有出錯,則降級處理  if (top.location.hostname != window.location.hostname) {     top.location.href =window.location.href;  }}catch(e){  top.location.href = window.location.href;}

    這只是瀏覽器端,對iframe頁面的權限做出相關的設置。我們還可以在服務器上,對使用iframe的權限進行設置.

    X-Frame-Options

    X-Frame-Options是一個相應頭,主要是描述服務器的網頁資源的iframe權限。目前的支持度是IE8+(已經很好了啊喂)有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

    ok, 上面基本上就是防止自己頁面被嵌套而做的一些安全防護工作。 當然,我們面臨的安全問題還有一個,就是當iframe別人的頁面時,我們需要對其進行安全設限,雖然,跨域時iframe的安全性會大很多,但是,互聯網是沒有安全的地方。在以前,我們會進行各種trick來防止自己的頁面被污染,現在h5提供的一個新屬性sandbox可以很好的解決這個問題。

    sandbox

    sandbox就是用來給指定iframe設置一個沙盒模型限制iframe的更多權限.

    sandbox是h5的一個新屬性,IE10+支持(md~).

    啟用方式就是使用sandbox屬性:

    這樣會對iframe頁面進行一系列的限制:

    1. script腳本不能執行

    2. 不能發送ajax請求

    3. 不能使用本地存儲,即localStorage,cookie等

    4. 不能創建新的彈窗和window

    5. 不能發送表單

    6. 不能加載額外插件比如flash等

      看到這里,我也是醉了。 好好的一個iframe,你這樣是不是有點過分了。 不過,你可以放寬一點權限。在sandbox里面進行一些簡單設置

    常用的配置項有:

    配置 效果
    allow-forms 允許進行提交表單
    allow-scripts 運行執行腳本
    allow-same-origin 允許同域請求,比如ajax,storage
    allow-top-navigation 允許iframe自身能夠進行頁面跳轉
    allow-popups 允許iframe中彈出新窗口
    allow-pointer-lock 在iframe中可以鎖定鼠標,主要和 鼠標鎖定 有關

    可以通過在sandbox里,添加允許進行的權限.

    這樣,就可以保證js腳本的執行,但是禁止iframe里的javascript執行top.location = self.location。

    哎,其實,iframe的安全問題還是超級有的。比如l ocation劫持,Refers檢查 等。 不過目前而言,知道怎么簡單的做一些安全措施就over了,白帽子們會幫我們測試的。

    resolve iframe跨域

    iframe就是一個隔離沙盒,相當于我們在一個頁面內可以操控很多個標簽頁一樣。如果踩坑的童鞋應該知道,iframe的解決跨域也是很有套套的。

    首先我們需要明確什么是跨域。

    瀏覽器判斷你跨沒跨域,主要根據兩個點。 一個是你網頁的協議(protocol),一個就是你的host是否相同,即,就是url的首部:

    window.location.protocol +window.location.host

    具體的例子就是:

    需要強調的是,url首部必須一樣,比如:二級域名或者IP地址,都算是跨域.

    //域名和域名對應ip, 跨域http://www.a.com/a.jshttp://70.32.92.74/b.js//統一域名,不同二級域名。 跨域http://www.a.com/a.jshttp://a.com/b.js

    對于第二種方式的跨域(主域相同而子域不同),可以使用iframe進行解決。

    在兩個不同子域下(某一方使用iframe嵌套在另一方),

    即:

    http: //www.foo.com/a.html和http: //script.foo.com/b.html

    兩個文件中分別加上document.domain = ‘foo.com’,指定相同的主域,然后,兩個文檔就可以進行交互。

    //b.html是以iframe的形式嵌套在a.html中//www.foo.com上的a.htmldocument.domain = 'foo.com';var ifr = document.createElement('iframe');ifr.src = 'http://script.foo.com/b.html';ifr.style.display = 'none';document.body.appendChild(ifr);ifr.onload = function(){ var doc = ifr.contentDocument || ifr.contentWindow.document; // 在這里操縱b.html alert(doc.getElementsByTagName("h1")[0].childNodes[0].nodeValue);};//script.foo.com上的b.htmldocument.domain = 'foo.com';

    默認情況下document.domain 是指window.location.hostname. 你可以手動更改,但是最多只能設置為主域名。 通常,主域名就是指不帶www的hostname, 比如: foo.com , baidu.com 。 如果,帶上www或者其他的前綴,就是二級域名或者多級域名。通過上述設置,相同的domain之后,就可以進行同域的相關操作。另外還可以使用iframe和location.hash,不過由于技術out了,這里就不做介紹了。

    H5的CDM跨域與iframe

    如果你設置的iframe的域名和你top window的域名完全不同。 則可以使用CDM(cross document messaging)進行跨域消息的傳遞。該API的兼容性較好 ie8+都支持.

    發送消息: 使用postmessage方法

    接受消息: 監聽message事件

    postmessage

    該方法掛載到window對象上,即,使用window.postmessage()調用.

    該方法接受兩個參數:postMessage(message, targetOrigin):

    message: 就是傳遞給iframe的內容, 通常是string,如果你想傳object對象也可以。不過使用前請參考這一句話:

    Objects listed in transfer are transferred, not just cloned, meaning that they are no longer usable on the sending side.

    意思就是,希望親愛的不要直接傳Object。 如果有條件,可以使用是JSON.stringify進行轉化。這樣能保證不會出bug.

    targetOrigin: 接受你傳遞消息的域名,可以設置絕對路徑,也可以設置” “或者”/”。 表示任意域名都行,”/”表示只能傳遞給同域域名。

    來個栗子:

    //當前腳本let ifr = window.frames['sendMessage']; //使用iframe的window向iframe發送message。ifr.postmessage('give u a message', "http://tuhao.com");//tuhao.com的腳本window.addEventListener('message', receiver, false);function receiver(e) { if (e.origin == 'http://tuhao.com') { if (e.data == 'give u a message') { e.source.postMessage('received', e.origin); //向原網頁返回信息 } else { alert(e.data); } }}

    當targetOrigin接受到message消息之后,會觸發message事件。 message提供的event對象上有3個重要的屬性,data,origin,source.

    data:postMessage傳遞進來的值origin:發送消息的文檔所在的域source:發送消息文檔的window對象的代理,如果是來自同一個域,則該對象就是window,可以使用其所有方法,如果是不同的域,則window只能調用postMessage()方法返回信息

    屬性的使用方法,如上頭那個demo 說的。 很貼切, 很完美~

    finally iframe

    iframe的大概我們差不多了解了。 想說的是,iframe 在后面會越用越少的。但是應該是不會被w3c標準廢除的。到是前端的發展,真尼瑪太快了,每過一段時間,一個新工具,新技術的出現,好到是好,不過學的真心蛋疼。不過,我們要以一個大前端的姿態要求我們,md,現在不學,那什么時候學~

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    iframe,我們來談一談_html/css

    iframe,我們來談一談_html/css_WEB-ITnose:某大咖說: iframe是能耗最高的一個元素,請盡量減少使用 某大牛說: iframe安全性太差,請盡量減少使用 … wtf, 你們知不知道你們這樣澆滅了多少孩紙學習iframe的熱情和決心。 雖然,你們這樣說的我竟無法反駁,但是iframe強大功能是不容忽視的
    推薦度:
    標簽: html 我們 iframe
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 亚洲午夜久久久精品影院| 国产一区二区三区欧美精品| 人妻少妇精品中文字幕av蜜桃| 91原创国产精品| 亚洲无线观看国产精品| 精品久久久久一区二区三区 | 国内精品久久久久影院优| 久久久久国产精品嫩草影院| 亚洲国产精品自在线一区二区| 55夜色66夜色国产精品视频| 亚洲精品乱码久久久久久久久久久久 | 国产99视频精品专区| 99精品视频在线观看re| 精品久久人妻av中文字幕| 亚洲级αV无码毛片久久精品| 日产国产精品亚洲系列| 日本熟妇亚洲欧美精品区| 国产精品一区在线观看你懂的| 欧美精品一本久久男人的天堂| 国产亚洲欧美精品久久久| 日韩精品一区二区三区中文| 无码国产69精品久久久久网站| 亚洲国产综合精品中文字幕| 欧美亚洲日本久久精品| 欧美精品综合视频一区二区| 欧美精品91欧美日韩操| 精品国产亚洲一区二区在线观看 | 99国内精品久久久久久久| 久久福利青草精品资源站免费| 99热这里只有精品在线| 丰满人妻熟妇乱又仑精品| 国产精品禁18久久久夂久| 国产精品女同久久久久电影院| 精品亚洲成a人片在线观看| 久久久久久久久无码精品亚洲日韩 | 亚洲国产成人久久精品99 | 国产呦小j女精品视频| 精品国产人成亚洲区| 日韩精品无码人妻一区二区三区| 亚洲精品国产成人影院| 一本一本久久A久久综合精品 |