国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

HTML阻止iframe跳轉(zhuǎn)頁面并使用iframe在頁面內(nèi)嵌微信網(wǎng)頁版的實現(xiàn)方法

2024-08-26 00:20:17
字體:
供稿:網(wǎng)友

就想弄一個winform結(jié)合html5的一個小東西,突有興致,想在里面嵌套一個微信網(wǎng)頁版。

好了,想法一出來,就行動吧,最終效果如下圖:

html,iframe跳轉(zhuǎn),iframe,微信網(wǎng)頁版

一開始就打算在頁面里面嵌套一個iframe指向https://wx.qq.com就OK了,但是我還是太天真,微信網(wǎng)頁版會自動跳轉(zhuǎn)。結(jié)果如下圖:

html,iframe跳轉(zhuǎn),iframe,微信網(wǎng)頁版

于是上網(wǎng)搜了一下阻止iframe跳轉(zhuǎn)的辦法,就是在iframe標(biāo)簽加上security="restricted"sandbox="" 兩個屬性。前者是IE的禁止js的功能,后者是HTML5的功能。

使用sandbox="allow-scripts allow-same-origin allow-popups"可以阻止跳轉(zhuǎn)。然而......結(jié)果卻是這樣:

html,iframe跳轉(zhuǎn),iframe,微信網(wǎng)頁版

然后發(fā)現(xiàn),這個跳轉(zhuǎn)其實就是關(guān)閉原先頁面之后在瀏覽到跳轉(zhuǎn)頁面。所以可以利用頁面關(guān)閉事件onbeforeunload來阻止跳轉(zhuǎn)。所以在頁面加入如下代碼:

 document.body.onbeforeunload = function (event) {             var rel = "asdfawfewf";             if (!window.event) {                event.returnValue = rel;            } else {                window.event.returnValue = rel;             }         };

然后發(fā)現(xiàn)結(jié)果還是這樣:

html,iframe跳轉(zhuǎn),iframe,微信網(wǎng)頁版

到底是什么原因呢?事件沒反應(yīng)?還是微信網(wǎng)頁版的跳轉(zhuǎn)太牛了?直接無視這個事件?于是我新建一個空白的html,單獨加上該事件進行驗證。

<!DOCTYPE html>   <html lang="en" xmlns="http://www.w3.org/1999/xhtml">  <head>      <meta charset="utf-8" />      <title></title>  </head>  <body></body>  <script>document.body.onbeforeunload = function (event) {    var rel = "asdfawfewf";     if (!window.event) {         event.returnValue = rel;     } else {         window.event.returnValue = rel;     } }; </script> </html>

結(jié)果卻是可行的:

html,iframe跳轉(zhuǎn),iframe,微信網(wǎng)頁版

但是在頁面里面嵌入iframe之后卻直接就跳轉(zhuǎn)了,大家可以嘗試一下面的代碼。

<!DOCTYPE html>   <html lang="en" xmlns="http://www.w3.org/1999/xhtml">  <head>      <meta charset="utf-8" />      <title></title>  </head>  <body>      <iframe src="https://wx.qq.com/" frameborder="0" style="position: absolute;border: navajowhite;left: 0;height: calc(100% - 30px);width:100%">     </iframe> </body> <script> document.body.onbeforeunload = function (event) {     var rel = "asdfawfewf";     if (!window.event) {         event.returnValue = rel;     } else {         window.event.returnValue = rel;     } }; </script> </html>

正在毫無計策的時候,我一直打開關(guān)閉嘗試該方法是否生效。突然發(fā)現(xiàn),如果頁面在剛打開的很短時間內(nèi)關(guān)閉頁面,onbeforeunload事件是不會被觸發(fā)的,在等待幾秒之后再關(guān)閉頁面就會觸發(fā)事件出現(xiàn)提示。

來,試一下iframe延時對src賦值(這里引用了JQuery)。

<!DOCTYPE html>  <html lang="en" xmlns="http://www.w3.org/1999/xhtml">  <head>      <meta charset="utf-8" />     <title></title>      <script src="scripts/jquery-2.2.3.js"></script>  </head>  <body>      <iframe id="iframe" frameborder="0" style="position: absolute;border: navajowhite;left: 0;height: calc(100% - 30px);width:100%">     </iframe> </body> <script> $(function () {     setTimeout(function () {         iframe.src = "https://wx.qq.com/";     },5000); }); document.body.onbeforeunload = function (event) {     var rel = "asdfawfewf";     if (!window.event) {         event.returnValue = rel;     } else {         window.event.returnValue = rel;     } }; </script> </html>

結(jié)果果然成功了,會出現(xiàn)提示是否離開此頁面,點擊留下按鈕。成功沒有跳轉(zhuǎn)。下圖為我成品圖片。

html,iframe跳轉(zhuǎn),iframe,微信網(wǎng)頁版

大功告成,里面可以正常聊天和傳文件,但是不能截圖。

html,iframe跳轉(zhuǎn),iframe,微信網(wǎng)頁版

缺點不足的就是,完成登陸需要點擊彈窗取消按鈕,而且需要兩次,第一次打開頁面,第二次掃碼結(jié)束后還會跳轉(zhuǎn)一次頁面。目前還沒辦法解決這個問題,希望有辦法解決此問題的朋友們可以提點建議哈~~小編會及時回復(fù)大家的,在此也非常感謝大家對VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 华蓥市| 晋州市| 获嘉县| 桓台县| 朔州市| 洪泽县| 崇文区| 崇阳县| 融水| 神池县| 桐庐县| 博兴县| 凤凰县| 镇巴县| 华宁县| 会同县| 舟曲县| 亳州市| 公安县| 都昌县| 咸阳市| 洛扎县| 濉溪县| 图木舒克市| 措美县| 独山县| 青川县| 谷城县| 巴里| 瓦房店市| 阜宁县| 常山县| 章丘市| 三明市| 屏南县| 武鸣县| 楚雄市| 昌吉市| 黄石市| 利川市| 台州市|