首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >30 Sec后显示部门

30 Sec后显示部门
EN

Stack Overflow用户
提问于 2015-06-02 09:06:41
回答 7查看 1.7K关注 0票数 2

我想给用户做个欢迎的信息。

我的计划是:

  • 如果用户第一次访问页面,则在30秒后显示一条div消息。
  • 如果用户已经访问了该页面,则不需要显示div消息。

我已经写了这段代码:

我的cookie代码

代码语言:javascript
复制
<script type="text/javascript">
function createCookie(name, value, days) {
    if (days) {
        var date = new Date();
        date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
        var expires = "; expires=" + date.toGMTString();
    } else var expires = "";
    document.cookie = name + "=" + value + expires + "; path=/";
}

function readCookie(name) {
    var nameEQ = name + "=";
    var ca = document.cookie.split(';');
    for (var i = 0; i < ca.length; i++) {
        var c = ca[i];
        while (c.charAt(0) == ' ') c = c.substring(1, c.length);
        if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length, c.length);
    }
    return null;
}

function eraseCookie(name) {
    createCookie(name, "", -1);
}
</script>

我的显示代码

代码语言:javascript
复制
<script type="text/javascript">
function showbox() {
    document.getElementById("apDiv1").style.visibility = "visible";

}
setTimeout("showbox()", 30000); // after 5 secs
</script>
<script type="text/javascript">
if (!readCookie('visitedPreviously')) {
    showbox();
    //document.write(' Your Message Goes Here And You See It Only Once ');
    createCookie('visitedPreviously', 'visitedPreviously', 3); // 365 days persistence
}

//eraseCookie('visitedPreviously');  // FOR TEST PURPOSES
</script>

我的问题是当访问者第一次访问页面时,div立即显示(30秒)-不工作

但是当返回的访问者再次访问该页面时,div将在30秒后显示。

我希望第一次用户访问显示30秒后的div消息。

请帮帮我。

EN

回答 7

Stack Overflow用户

发布于 2015-06-02 09:17:27

根据您的解释,您希望在30秒后只向新用户显示一个对话框。因此,您需要将代码更改为以下代码:

代码语言:javascript
复制
<script type="text/javascript">
function showbox() {
    document.getElementById("apDiv1").style.visibility = "visible";
}
if (!readCookie('visitedPreviously')) { //if he/she is a new user
     setTimeout("showbox()", 30000); // after 30 secs
    //document.write(' Your Message Goes Here And You See It Only Once ');
    createCookie('visitedPreviously', 'visitedPreviously', 3); // 365 days persistence
}

//eraseCookie('visitedPreviously');  // FOR TEST PURPOSES
</script>
票数 3
EN

Stack Overflow用户

发布于 2015-06-02 09:33:39

您需要删除showbox周围的引号。

这是setTimeout函数的语法,

代码语言:javascript
复制
setTimeout(function,milliseconds,param1,param2,...)

setTimeout期望第一个参数是函数调用。

代码语言:javascript
复制
function showbox() {
  document.getElementById("apDiv1").style.visibility = "visible";
  alert();

}
setTimeout(showbox, 30000); // after 5 secs

if (!readCookie('visitedPreviously')) {
  //I added a set timeout here which is what you need
  setTimeout(showbox, 30000); // after 5 secs
  //document.write(' Your Message Goes Here And You See It Only Once ');
  createCookie('visitedPreviously', 'visitedPreviously', 3); // 365 days persistence
}

//eraseCookie('visitedPreviously');  // FOR TEST PURPOSES

票数 2
EN

Stack Overflow用户

发布于 2015-06-02 09:12:41

删除"showbox()"中的引号和括号。如下所示:

代码语言:javascript
复制
setTimeout(showbox, 30000);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30591781

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档