校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > HTML阻止iframe跳轉頁面并使用iframe在頁面內嵌微信網頁版的實現方法

HTML阻止iframe跳轉頁面并使用iframe在頁面內嵌微信網頁版的實現方法

熱門標簽:高德地圖標注廁所 地圖標注沿海城市房價 地圖標注員工作內容 通遼地圖標注app 威海語音外呼系統平臺 智能語音電銷機器人客戶端 江西ai電銷機器人如何 中國地圖標注城市的 西安金倫外呼系統

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

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

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

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

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

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

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

然后發現結果還是這樣:

到底是什么原因呢?事件沒反應?還是微信網頁版的跳轉太牛了?直接無視這個事件?于是我新建一個空白的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>

結果卻是可行的:

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

<!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>

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

來,試一下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>

結果果然成功了,會出現提示是否離開此頁面,點擊留下按鈕。成功沒有跳轉。下圖為我成品圖片。

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

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

標簽:崇左 眉山 北海 晉中 營口 阜陽 河池 青海

巨人網絡通訊聲明:本文標題《HTML阻止iframe跳轉頁面并使用iframe在頁面內嵌微信網頁版的實現方法》,本文關鍵詞  HTML,阻止,iframe,跳轉,頁面,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML阻止iframe跳轉頁面并使用iframe在頁面內嵌微信網頁版的實現方法》相關的同類信息!
  • 本頁收集關于HTML阻止iframe跳轉頁面并使用iframe在頁面內嵌微信網頁版的實現方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 屏山县| 平昌县| 镇康县| 达孜县| 西林县| 行唐县| 大宁县| 拉萨市| 华容县| 台南县| 忻城县| 梧州市| 永兴县| 营口市| 宁夏| 波密县| 福清市| 枣强县| 张家川| 呼和浩特市| 竹山县| 富平县| 马龙县| 西乌珠穆沁旗| 威信县| 永嘉县| 沅陵县| 天祝| 勐海县| 镇巴县| 开原市| 柞水县| 伊宁市| 辉县市| 保定市| 兰考县| 宣城市| 万宁市| 滦平县| 三亚市| 广汉市|