现有数据:
id   title   reminddate(提醒时间)            authorid(发布人)
1    开会    2011-8-12 15:00:00    1
2    开会    2011-8-13 15:00:00    2怎么样实现消息提醒的功能啊,就是到了提醒时间,能弹出个提示...

解决方案 »

  1.   

    jquery ajax 定时刷新数据库内容 比较时间 
      

  2.   

    刚刚经理说不让用ajax做,说是占用客户端资源什么的...说是用cookie存,能行么???
      

  3.   

    用js的定时函数 不就OK了吗?
    把内容先存到cookie中
      

  4.   

    可以将数据库的提醒时间存在cookie或缓存中。用js每隔一秒就调用函数检查:setInterval("check()",1000);
    function check(){
        var arr=你提醒时间数组;
        var myDate = new Date();
       var d= myDate.toLocaleString( ).replace(/[年月]/g,'-');
       for(var i in arr) {
        if(arr[i] == d) {
            弹窗........
        }}参考。自己完善!
      

  5.   


    用cookie 不也要用js?不也要占用客户端资源? 只不过ajax 还有个服务器请求.但是你还不是要到服务器端去取有没新的消息?要不然这个cookie 怎么生成?当然如果你的消息是固定死的那就可以这么做。如果是即时的,比如XX 发一条消息给XX 要在什么时候提醒XX 就必须得用Ajax去请求数据.所以先弄明白你的这些消息是不是固定死的.如果是那么就用cookie 好了.
      

  6.   


    嗯啊我在php里设置了一个cookie,怎么在js中获取这个cookie啊$startdate="2011-8-28 18:34:30";
    setcookie("myCookie",$startdate);
      

  7.   

    1 setcookie.php<?php   //上面不能有空行
    setcookie('php_cn_ck','php_中文_cookie');
    setcookie('php_en_ck','php_english_cookie');
    ?>
    <script src="cookie.js"></script>
    <script>
    set_cookie('js_cn_ck','js_中文_cookie');
    set_cookie('js_en_ck','js_english_cookie');
    </script>
    <html>
    <meta http-equiv="Content-Type" content="text/html; charset=utf8">
    PHP cookie已经设置<br>php_cn_ck=php_中文_cookie<br>php_en_ck=php_english_cookie<br><br>
    JS cookie已经设置<br>js_cn_ck=js_中文_cookie<br>js_en_ck=js_english_cookie<br><br>
    <a href=getcookie.php>读取cookie</a><br>
    </html>2  getcookie.php<meta http-equiv="Content-Type" content="text/html; charset=utf8">
    一 读取php传送的中英文cookie<br><br>
    <p>1 php读取php设置php cookie<br><br>
    <?php
    include('function.php');
    $php_cn_ck=$_COOKIE['php_cn_ck'];
    $un_php_cn_ck=unescape($php_cn_ck);
    echo "解码前的中文cookie:php_cn_ck=$php_cn_ck<br><br>";
    echo "解码后的中文cookie:un_php_cn_ck=$un_php_cn_ck<br><br>";
    $php_en_ck=$_COOKIE['php_en_ck'];
    echo "英文cookie无需解码:php_en_ck=$php_en_ck<br><br>";
    ?>
    <p>2 js读取php设置cookie<br><br>
    <script src="cookie.js"></script>
    <script>
    php_cn_ck=get_cookie('php_cn_ck');
    un_php_cn_ck = decodeURIComponent (escape(php_cn_ck));
    document.write("解码前的中文cookie :php_cn_ck="+php_cn_ck+"<Br><br>");
    document.write("解码后的中文cookie :un_php_cn_ck="+un_php_cn_ck+"<Br><br>");
    php_en_ck=get_cookie('php_en_ck');
    document.write("英文cookie无需解码 :php_en_ck="+php_en_ck+"<Br><br>");
    </script>
    -----------------------------------------------<br>
    二 读取JS传送的中英文cookie<br><br>
    <p>1 php读取JS设置js cookie<br><br>
    <?php
    $js_cn_ck=$_COOKIE['js_cn_ck'];
    $un_js_cn_ck=unescape($js_cn_ck);
    echo "解码前的中文cookie:js_cn_ck=$js_cn_ck<br><br>";
    echo "解码后的中文cookie:un_js_cn_ck=$un_js_cn_ck<br><br>";
    $js_en_ck=$_COOKIE['js_en_ck'];
    echo "英文cookie无需解码:js_en_ck=$js_en_ck<br><br>";
    ?>
    </p>
    <p>2 js读取js设置的cookie<br><br>
    <script>
    js_cn_ck=get_cookie('js_cn_ck');
    document.write("解码前的中文cookie :js_cn_ck="+js_cn_ck+"<Br><br>");
    //un_js_cn_ck = decodeURIComponent (escape(js_cn_ck)); 调用这两句会出现js解析中断
    //document.write("解码后的中文cookie :un_js_cn_ck="+un_js_cn_ck+"<Br><br>");
    js_en_ck=get_cookie('js_en_ck');
    document.write("英文cookie无需解码 :js_en_ck="+js_en_ck+"<Br><br>");
    </script>
    </p><pre>
    总结: 1 php用自身函数读取php 的cookie,没有任何障碍,无需解码处理.
      2 js采用cookie.js方法读取js 的cookie,没有任何障碍,无需解码处理.
      
      3 js读取php的中文cookie,需要做 "decodeURIComponent (escape(php_cn_ck)) "函数处理
      
      4 php读取js的中文cookie 需要做 " unescape()" 函数处理
    </pre>文件中的函数包文件如下3 cookie.jsfunction set_cookie(name, value, expires, path, domain, secure) 
    {
    // set time, it's in milliseconds
    var today = new Date();
    today.setTime( today.getTime() );if ( expires )
    {
    expires = expires * 1000 * 60 * 60 * 24;
    }
    var expires_date = new Date( today.getTime() + (expires) );document.cookie = name + "=" +escape( value ) +
    ( ( expires ) ? ";expires=" + expires_date.toGMTString() : "" ) + 
    ( ( path ) ? ";path=" + path : "" ) + 
    ( ( domain ) ? ";domain=" + domain : "" ) +
    ( ( secure ) ? ";secure" : "" );
    }
    /*
    * This will retrieve the cookie by name, if the cookie does not exist, it will return false, so you can do things like 
    * if ( Get_Cookie( 'your_cookie' ) ) do something.
    */
    function get_cookie(name) {
    var start = document.cookie.indexOf(name + "=");
    var len = start + name.length + 1;
    if ((!start) && (name != document.cookie.substring(0, name.length )))
    {
      return null;
    }
    if (start == -1) return null;
    var end = document.cookie.indexOf(";", len);
    if (end == -1) end = document.cookie.length;
    return unescape(document.cookie.substring(len, end));
    }4 function.phpfunction unescape($str) {
    $str = rawurldecode ( $str );
    preg_match_all ( "/(?:%u.{4})|&#x.{4};|&#d+;|.+/U", $str, $r );
    $ar = $r [0];
    foreach ( $ar as $k => $v ) {
      if (substr ( $v, 0, 2 ) == "%u") {
       if (! eregi ( "WIN", PHP_OS )) {
        $tmpString = "%u" . substr ( $v, 4, 2 ) . substr ( $v, 2, 2 );
       }
       $ar [$k] = iconv ( "UCS-2", "utf-8", pack ( "H4", substr ( $tmpString, - 4 ) ) );
      } elseif (substr ( $v, 0, 3 ) == "&#x")
       $ar [$k] = iconv ( "UCS-2", "utf-8", pack ( "H4", substr ( $v, 3, - 1 ) ) );
      elseif (substr ( $v, 0, 2 ) == "&#") {
       $ar [$k] = iconv ( "UCS-2", "utf-8", pack ( "n", substr ( $v, 2, - 1 ) ) );
      }
    }
    return join ( "", $ar );
    }
      

  8.   


    就是这么获取??、不是吧var myCookie=get_cookie('myCookie');