0

这是我的 JavaScript 代码。

<SCRIPT TYPE="text/javascript">
<!--
function popup(mylink, windowname) {
    if (! window.focus) return true;
    var href;
    if (typeof mylink  == 'string')
        href=mylink;
    else
        href = mylink.href;
    window.open(href, windowname, 'width=500,height=500,scrollbars=yes');
    return false;
}
//-->
</SCRIPT>

仅使用上面的代码,弹出窗口完全符合我的要求,但它似乎紧贴在左上角。我希望弹出窗口居中。

我在这个网站上尝试了几个建议(例如:

var left = screen.width / 2 - w / 2;
var top = screen.height / 2 - h / 2;

但是将其他任何内容插入我已经拥有的代码中会使弹出窗口在同一浏览器的新选项卡中打开(忽略弹出功能)。

这就是我来这里要解决的问题。

此外,我想淡化背景以将读者的注意力吸引到弹出窗口上。有没有我可以扔进去的javascript片段?

4

2 回答 2

0

试试这个:

function popupW(mylink, windowname) {
    var href;
    var w = h = 500;
    var left = (screen.width/2) - (w/2);
    var top = (screen.height/2) - (h/2);

    if(!window.focus) {
        return true;
    }

    if(typeof mylink == 'string') {
        href = mylink;
    } else {
        href = mylink.href;
    }

    window.open(href, windowname, 'width='+w+', height='+h+', scrollbars=yes, top='+top+', left='+left);
    return false;
}
popupW('http://google.com', 'google');

背景窗口的淡化可以通过创建叠加来完成。

var overlay = document.createElement('div');
overlay.setAttribute('id', 'overlay');
document.body.appendChild(overlay);

使用以下 CSS 样式:

#overlay {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgba(0,0,0,0.5);
    z-index: 99999;
}
于 2012-12-18T00:06:05.350 回答
0

你可以试试这个

function popup(mylink, windowname)
{
    if (typeof(mylink) !== 'string') mylink=mylink.href;
    var l=(screen.width-500)/2, t=(screen.height-500)/2;
    window.open(mylink, windowname, 'width=500,height=500,scrollbars=1,left='+l+',top='+t);
    return false;
}

popup('http://heera.it', 'hit');

例子。

于 2012-12-18T00:08:30.990 回答