解決JS彈出新視窗被瀏覽器阻止的解決方案
本文轉載自:http://blog.csdn.net/cntanghai/article/details/6643522
在js中通過open彈出視窗可能會被阻止,我嘗試這段程式碼:
var flag = window.open(url,"","");
if(flag==null) {
alert("您的瀏覽器啟用彈出視窗過濾功能!\n\n請暫時先關閉此功能!") ;
}
上面這段程式碼僅僅是增加了一個提示,讓使用者更改瀏覽器設定.但實際上無任何作用.使用下面的解決方案後,在IE中測試,一般不會被阻止,即使被阻止,ie也會彈出讓使用者選擇是否<pre name="code" class="html">1.新新增一個Form
<form id="EmailForm" action="目標頁" method="get" target="_blank">
<input id="emailid" name="emailid" type="hidden" />//隱藏域,用來放需要傳遞的引數
</form>
注意form的target屬性要設定成_blank
2.提交這個Form
function btnEditEmail_onclick() {
document.getElementById("emailid").value=id;//初始隱藏域
document.getElementById("EmailForm").submit();//提交
}
這樣,就會開啟新視窗定向到目標頁了,而且不會被阻止,同時用新視窗的window.opener還能訪問原視窗。
本段內容引自:http://hi.baidu.com/hy0kl/blog/item/486c01f31882e55c352acc1a.html
允許彈出視窗.所以說這種解決方案是行之有效的.
我的程式碼:
<%@ page language="java" pageEncoding="utf-8"%>
<%@ include file="/summer/component/common/sys.jsp"%>
<%@ include file="/summer/jsp/head/taglibs.jsp"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link href="<c:url value='/css/css.css'/>" rel="stylesheet" type="text/css" />
<title>密碼確認</title>
<script type="text/javascript">
function tijiao(){ // 提交
var password = document.getElementById("password").value;
var map = new Map();
map.put('key', 'maintain.checkPassWord');
map.put('password', password);
var query = new QueryObj(map, chakanHeTongjiCallback);
query.send();
}
function chakanHeTongjiCallback(query) {
if(query.getDetail()=='false'){
alert('密碼輸入錯誤,請重試!');
return;
}
var type = document.getElementById("type").value;
var cpbbh = document.getElementById("cpbbh").value;
var plx = document.getElementById("plx").value;
if(type=='1') { // 投票詳情
toupiao(cpbbh,plx);
}else if(type=='2') { //統計
var submitForm = document.getElementById("tongjiForm");
submitForm.submit();
window.close();
}
}
function toupiao(cpbbh,plx){
var map = new Map();
map.put('key', 'maintain.judge');
map.put('cpbbh', cpbbh);
map.put('plx', plx);
var query = new QueryObj(map, toupiaoCallback);
query.send();
}
function toupiaoCallback(query) {
if(query.getDetail()=='false'){
alert('該測評表沒有任何參與投票資訊');
return;
}
var submitForm = document.getElementById("toupiaoxiangqingForm");
submitForm.submit();
window.close();
}
</script>
</head>
<body>
<center>
<div>
<div width="390"> </div>
<div width="390">請輸入您的密碼:</div>
<table>
<tr><td><input type="password" id="password" name="userPasWord" /></td></tr>
</table>
</div>
<br>
<br>
<div>
<input name="submit" type="submit" onclick="tijiao()" value="提交" class="anniu6" />
<input name="submit" type="button" onclick="window.close();" value="關閉" class="anniu6" />
</div>
<ui:hidden name="type" value="${type }"></ui:hidden>
<ui:hidden name="cpbbh" value="${cpbbh }"></ui:hidden>
<ui:hidden name="plx" value="${plx }"></ui:hidden>
</center>
<%-- 統計 --%>
<form action="../mzcp/voteDetail.do?action=statisticsVoteDetail" id="tongjiForm" method="post" target="_blank">
<ui:hidden name="NCpbbh" value="${cpbbh }"></ui:hidden>
<ui:hidden name="NPlx" value="${plx }"></ui:hidden>
</form>
<%--投票詳情 --%>
<form action="../mzcp/voteDetail.do?action=singleVoteDetail" id="toupiaoxiangqingForm" method="post" target="_blank">
<ui:hidden name="NCpbbh" value="${cpbbh }"></ui:hidden>
<ui:hidden name="NPlx" value="${plx }"></ui:hidden>
<ui:hidden name="index" value="0"></ui:hidden>
</form>
</body>
</html>
相關文章
- 解決ajax回撥window.open瀏覽器阻止彈窗問題瀏覽器
- QTP測試多個瀏覽器視窗的解決方案QT瀏覽器
- 使用window.open開啟新視窗被瀏覽器攔截的解決方案瀏覽器
- Edge瀏覽器被搜狗瀏覽器篡改的解決方法瀏覽器
- 解決新版谷歌瀏覽器無法關閉視窗的問題谷歌瀏覽器
- chrome瀏覽器最小字號解決方案Chrome瀏覽器
- 視窗被攔截的解決方法
- 突破瀏覽器域名併發限制的解決方案瀏覽器
- 瀏覽器支援ES6的最優解決方案瀏覽器
- 如何防止window.open彈窗被瀏覽器遮蔽瀏覽器
- angular瀏覽器相容性問題解決方案Angular瀏覽器
- 瀏覽器同源策略及 Ajax 跨域解決方案瀏覽器跨域
- 實現瀏覽器跨域解決方案介紹瀏覽器跨域
- js獲取瀏覽器視窗的大小JS瀏覽器
- jqueryeasyUI dialog 彈出視窗超出瀏覽器jQueryUI瀏覽器
- win10如何徹底解決彈窗廣告 win10阻止電腦彈窗廣告Win10
- 關閉瀏覽器視窗彈出警告視窗程式碼例項瀏覽器
- 主流瀏覽器相容性問題與解決方案瀏覽器
- 瀏覽器相容性問題解決方案 · 總結瀏覽器
- Google瀏覽器主頁被搜狗導航劫持解決方法Go瀏覽器
- js獲取瀏覽器視窗屬性JS瀏覽器
- HTML5支援所有瀏覽器的SHIV解決方案HTML瀏覽器
- SSL-Explorer基於web瀏覽器的VPN解決方案Web瀏覽器
- 瀏覽器突然不能訪問某些可用網站解決方案瀏覽器網站
- 最新Iframe全瀏覽器相容自適應高度解決方案瀏覽器
- WKWebView不顯示JS的alert彈窗的解決辦法WebViewJS
- 域名被牆怎麼解決,域名被牆怎麼解決,解決方案
- 瀏覽器 history location pushstate的解決疑問瀏覽器
- 解決瀏覽器解析度問題瀏覽器
- 用jquery解決瀏覽器相容問題jQuery瀏覽器
- windows10瀏覽器老是無法正常開啟解決方案Windows瀏覽器
- 新型BI解決方案:SaaS BI,在瀏覽器上分析資料瀏覽器
- 谷歌瀏覽器表單只能夠提交一次解決方案谷歌瀏覽器
- IE低版本瀏覽器document.referrer丟失解決方案瀏覽器
- 解決方案| anyRTC金融音視訊解決方案
- win10 edge瀏覽器打不開視訊的解決方法Win10瀏覽器
- 關閉瀏覽器視窗彈出提示程式碼例項瀏覽器
- 谷歌瀏覽器下jquery無法獲取圖片的尺寸解決方案谷歌瀏覽器jQuery