php iframe跳转页面跳转页面,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"可以阻止跳转。然而......结果却是这样:

200c462255cb79089aad7a95c3825895.png

然后发现,这个跳转其实就是关闭原先页面之后在浏览到跳转页面。所以可以利用页面关闭事件onbeforeunload来阻止跳转。所以在页面加入如下代码:document.body.onbeforeunload = function (event) {

var rel = "asdfawfewf";

if (!window.event) {

event.returnValue = rel;

} else {

window.event.returnValue = rel;

}

};

然后发现结果还是这样:

到底是什么原因呢?事件没反应?还是微信网页版的跳转太牛了?直接无视这个事件?于是我新建一个空白的html,单独加上该事件进行验证。

document.body.onbeforeunload = function (event) {

var rel = "asdfawfewf";

if (!window.event) {

event.returnValue = rel;

} else {

window.event.returnValue = rel;

}

};

结果却是可行的:

9254936d6774f53d0b05cc59af86292f.png

但是在页面里面嵌入iframe之后却直接就跳转了,大家可以尝试一下面的代码。

document.body.onbeforeunload = function (event) {

var rel = "asdfawfewf";

if (!window.event) {

event.returnValue = rel;

} else {

window.event.returnValue = rel;

}

};

正在毫无计策的时候,我一直打开关闭尝试该方法是否生效。突然发现,如果页面在刚打开的很短时间内关闭页面,onbeforeunload事件是不会被触发的,在等待几秒之后再关闭页面就会触发事件出现提示。

来,试一下iframe延时对src赋值(这里引用了JQuery)。

$(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;

}

};

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

3ed0e92c07326616ffa9613bfb81b759.png

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

8720e31edb784bc6a4eecc712d50b9c2.png

缺点不足的就是,完成登陆需要点击弹窗取消按钮,而且需要两次,第一次打开页面,第二次扫码结束后还会跳转一次页面。目前还没办法解决这个问题,希望有办法解决此问题的朋友们可以提点建议。

相关推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值