我有一个要求,我需要从父窗口打开一个弹出窗口。我能够成功地做到这一点。
现在我要做的是-假设一个弹出窗口打开并且该弹出窗口中有一些链接,如果我尝试单击该链接,它应该在新窗口中打开该链接并且原始弹出窗口应该关闭.
这是我的小提琴。在这个小提琴中,如果您单击应用按钮,那么它将打开一个工作正常的弹出窗口,但是如果您单击该弹出窗口中的任何链接,则该链接将在同一个弹出窗口中打开,这是我不想要的。我想在新的外部窗口中打开该链接,并且应该关闭原来的弹出窗口。
下面是JS代码-
function open(url) {
$('#blockdiv').fadeIn();
$('#iframe').attr('src', url);
$('#containerdiv').fadeIn();
}
function close() {
$('#blockdiv').fadeOut();
$('#containerdiv').fadeOut();
}
$(document).ready(function() {
$('ul').css({width: $('#containerdiv').width(),height: $('#containerdiv').height()})
$('#close').click( function() { close() })
$('.JN_apply').click( function() { open($(this).data('url')); })
});
我在小提琴中给出的示例将打开 www.ebay.com 网站,但一般来说,我的页面将作为弹出窗口打开。
有可能吗?如果是的话,有人可以帮我吗?
更新代码:-
现在我已经开始使用 jQuery colorbox 来做同样的事情了——
下面是我的父窗口代码,它将打开弹出窗口-
<!DOCTYPE html>
<html>
<head>
<meta charset='utf-8'/>
<title>Colorbox Examples</title>
<style>
body{font:12px/1.2 Verdana, sans-serif; padding:0 10px;}
a:link, a:visited{text-decoration:none; color:#416CE5; border-bottom:1px solid #416CE5;}
h2{font-size:13px; margin:15px 0 0 0;}
</style>
<link rel="stylesheet" href="C:\Users\rj\Downloads\colorbox-master\example4\colorbox.css" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="C:\Users\rj\Downloads\colorbox-master\jquery.colorbox.js"></script>
<script>
$(document).ready(function(){
//Examples of how to assign the Colorbox event to elements
$(".iframe").colorbox({iframe:true, width:"80%", height:"80%"});
});
</script>
</head>
<body>
<h2>Other Content Types</h2>
<p><a class='iframe' href="http://www.wikipedia.com">Outside Webpage (Iframe)</a></p>
</body>
</html>
下面是我的弹出窗口代码,它将有一个链接,我需要通过关闭原始弹出窗口在新的外部窗口中打开该链接-
<html>
<head>
<title>Apply</title>
</head>
<body>
<script>
function getUrlParameters() {
var vars = {};
var parts = window.location.href.replace(/[?&]+([^=&]+)=([^&]*)/gi,
function(m,key,value) {
vars[key] = value;
});
return vars;
}
var id = getUrlParameters()["ID"];
var title = getUrlParameters()["Title"];
var id = unescape(id);
var title = unescape(title);
var myJScript = document.createElement('script');
myJScript.setAttribute('type', 'Apply');
myJScript.setAttribute('data-companyId', '40');
myJScript.setAttribute('data-jobTitle', id );
myJScript.setAttribute('data-email', 'admin@domain.net');
document.body.appendChild(myJScript);
</script>
<hr>
<input name="Apply Online" type="button" id="Apply Online" value="Apply Online" ONCLICK="window.location.href='some_url'">
</body>
</html>
现在如何在单击“在线申请”链接后在这种情况下关闭弹出窗口,并且“在线申请”链接应该在新的外部窗口中打开?我希望这个问题应该足够清楚。