1

我有一个要求,我需要从父窗口打开一个弹出窗口。我能够成功地做到这一点。

现在我要做的是-假设一个弹出窗口打开并且该弹出窗口中有一些链接,如果我尝试单击该链接,它应该在新窗口中打开该链接并且原始弹出窗口应该关闭.

这是我的小提琴。在这个小提琴中,如果您单击应用按钮,那么它将打开一个工作正常的弹出窗口,但是如果您单击该弹出窗口中的任何链接,则该链接将在同一个弹出窗口中打开,这是我不想要的。我想在新的外部窗口中打开该链接,并且应该关闭原来的弹出窗口。

下面是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>

现在如何在单击“在线申请”链接后在这种情况下关闭弹出窗口,并且“在线申请”链接应该在新的外部窗口中打开?我希望这个问题应该足够清楚。

4

1 回答 1

2

尝试

<input name="Apply Online" type="button" id="Apply Online" value="Apply Online" ONCLICK="window.location.href='some_url';$.colorbox.close();">

或者

<input name="Apply Online" type="button" id="Apply Online" value="Apply Online" ONCLICK="window.location.href='some_url';parent.$.colorbox.close();">

于 2013-07-29T03:43:03.217 回答