首页前端开发HTMLHTML阻止iframe跳转页面并使用iframe在页面内嵌微信网页版的实现方法

HTML阻止iframe跳转页面并使用iframe在页面内嵌微信网页版的实现方法

时间2024-01-26 21:15:03发布访客分类HTML浏览358
导读:收集整理的这篇文章主要介绍了HTML阻止iframe跳转页面并使用iframe在页面内嵌微信网页版的实现方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 就想弄一个winform结合htML5的一个小东西,突有兴致,想在里面...
收集整理的这篇文章主要介绍了HTML阻止iframe跳转页面并使用iframe在页面内嵌微信网页版的实现方法,觉得挺不错的,现在分享给大家,也给大家做个参考。

就想弄一个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>
    

结果果然成功了,会出现提示是否离开此页面,点击留下按钮。成功没有跳转。下图为我成品图片。

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

缺点不足的就是,完成登陆需要点击弹窗取消按钮,而且需要两次,第一次打开页面,第二次扫码结束后还会跳转一次页面。目前还没办法解决这个问题,希望有办法解决此问题的朋友们可以提点建议哈~~小编会及时回复大家的,在此也非常感谢大家对网站的支持!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

htmliframe

若转载请注明出处: HTML阻止iframe跳转页面并使用iframe在页面内嵌微信网页版的实现方法
本文地址: https://pptw.com/jishu/587287.html
html+css+js 实现拍照预览上传图片功能 网页制作中注意应用HTML标签的问题

游客 回复需填写必要信息