以javascript弹出窗口为中心

时间:2012-12-17 23:56:54

标签: javascript popup centering

这是我的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片段会这样做?

2 个答案:

答案 0 :(得分: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;
}

答案 1 :(得分: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');

Example.