Open links, one after another

2019-03-02 02:59发布

I'm making a website where I'm opening a new window every 30 seconds. I got it to open the new windows properly, but I would like it to close the last window opened before opening the new one, so only one window is open at a time. How would I do this? Here's my code so far:

<script type="text/javascript">
function open_win() {
    window.open("http://www.wol.com");
    setTimeout(window.open('http://www.bol.com'),35000);
    setTimeout(window.open('http://lol.com'),70000);
    setTimeout(window.open('http://col.com'),105000);

}
</script>

3条回答
倾城 Initia
2楼-- · 2019-03-02 03:18

You can use a string array to store all of the links, and then iterate through that loop calling open and close after 30 seconds. Using a loop and abstracting open/close allows you to have as many links as you'd like.

var linkArray = ['http://www.wol.com', 'http://www.bol.com', 'http://lol.com', ['http://col.com']

function openWin(link) { 
    var currentWindow = window.open(link);
    setTimeout(currentWindow.close(), 30000);
}

function runLinks() {
    for(var i = 0; i< linkArray.length; i++) {
          openWin(linkArray[i]);
    }
}
查看更多
小情绪 Triste *
3楼-- · 2019-03-02 03:26

You can close a window opened by calling window.close on window.open's return value. So:

<script type="text/javascript">
function open_win() {
    var wol,bol,lol;
    wol=window.open("http://www.wol.com");
    setTimeout(function(){window.close(wol);bol=window.open('http://www.bol.com')},35000);
    setTimeout(function(){window.close(bol);lol=window.open('http://lol.com')},70000);
    setTimeout(function(){window.close(lol);window.open('http://col.com')},105000);

}
</script>
查看更多
欢心
4楼-- · 2019-03-02 03:28

Here a small interval loop for calling urls. Feel free to add an array for different URLS.

<script type="text/javascript">
    var lastWindow = "";
    setInterval(function(){
        if(lastWindow != ""){ lastWindow.close(); }
        lastWindow = window.open("url");
    }, 30000);
</script>
查看更多
登录 后发表回答