ThinkPHP结合ajax、Mysql实现的客户端通信功能代码示例


Posted in PHP onJune 23, 2014

该实例通过ThinkPHP结合Ajax与mysql实现了客户端的通信功能,具体如下:

1、使用js的ajax局部刷新功能,每次刷新将数据库中读取出的新记录插入到页面的显示区域,代码如下:

window.onload =setInterval(showWords1000);//加载完成之后开始执行刷新功能
function showWords()//刷新时被调用函数,实现ajax请求
   { 
    xmlHttp=GetXmlHttpObject();//从自定义的函数中获取请求对象。
    if (xmlHttp==null)
    {
     alert ("Browser does not support HTTP Request")
     return;
    }
    var url="index.php?g=Ksks&m=Comments&a=refresh";//要请求的路径使用shuipfcms框架,所以g是分组,m是action控制器,a是模板
    url=url+"&data_id="+$("#data_id").val();//接上,data_id传的参数,用于查询数据库的id
    url=url+"&lasttime="+$("i").last().siblings('input').val();//lasttime是页面显示数据的最后一个记录的时间戳,查找时根据大于这个时间戳的条件查找
    xmlHttp.onreadystatechange=stateChanged;//响应状态改变时调用的函数
    xmlHttp.open("GET",url,true);//使用get方法提交
    xmlHttp.send();//上面传参之后,这句可要可不要
   }
   function stateChanged() //实现向页面插入数据功能
   { 
   var str =""; 
    if(xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
    { 
     eval("var arrs="+xmlHttp.responseText);//获取由action响应输出的数据,因为数据室php数组格式,需用eval或json转化成js数组格式
     var chdiv=$("#conversation_history");//通信聊天记录框
     for(var j=0;j<arrs.length;j++){//循环插入数据
        var obj=$("<tr><td><h3></h3></td><td></td></tr>");//定义页面当中记录框的html格式代码
    var i=$("<i>  "+arrs[j].times+"</i><input type='hidden' value='"+arrs[j].times+"'>");//i标签i为thinkphp定义的直接将时间输出到input隐藏并且存储得到数据里面的聊天发送时间
    var p=$("<p></p>");
    p.html(arrs[j].content);//聊天内容
    p.append(i);
    var h3value=arrs[j].name;//发送的作者
    obj.find("h3").html(h3value+":");
    if(h3value=="主持人")
    {obj.find("h3").addClass("presenter");}//主持人会特别显示
    obj.find("td:last").append(p);
        chdiv.append(obj);//追加到table里面
     }
     chdiv.parent().scrollTop(chdiv.parent()[0].scrollHeight+0);//滚动到底部
    } 
   }
function GetXmlHttpObject()//定义ajax请求对象
   {
    var xmlHttp=null;
    try
    {
     // Firefox, Opera 8.0+, Safari
     xmlHttp=new XMLHttpRequest();
    }
    catch (e)
    {
     //Internet Explorer
     try
     {
      xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
     }
     catch (e)
     {
      xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
     }
    }
    return xmlHttp;
   }

2、action控制器,代码如下:

function refresh(){
   $data_id = I('get.data_id');//获得嘉宾id
   $lasttime = I('get.lasttime');
   //print_r(date("Y-m-d H:i:s",$lasttime));
   if(!$data_id)
    $this->error("该访谈不存在!"); 
   $data = M("ksks_words_memoir");
   
   //print_r(date('Y-m-d H:i:s',$lasttime));
   if(!$data)
    $this->error("初始化数据失败!");
   //$words = $data->where(array('dataid' => $data_id))->order('time asc')->select();
   //print_r($data->where(array('time' => $lasttime))->select());
   $where['time'] = array('gt',$lasttime);
   $count = $data->where($where)->count();
   //print_r(date("Y-m-d H:i:s",$lasttime));
   $words = $data->where($where)->select();
   $datas = array();//要返回的数组
   $i = 0;
   foreach($words as $word)
   {
    $datas[$i]['name'] = $word['name'];
    $datas[$i]['content'] = $word['content'];
    $datas[$i]['times'] = date('Y-m-d H:i:s',$word['time']);
    $lasttime = $word['time'];
    $i = $i+1;
   }
   setCookie('lasttime',$lasttime);
   $datas = json_encode($datas);
   //$this->cache();
   echo $datas;
 }

3、聊天页面,代码如下:

<volist name="words" id="vo">
<tr>
<td><h3 <if condition="$vo['name']=='主持人'">class="presenter"</if>>{$vo.name}:</h3></td>
<td>
<div>{$vo.content}<i>  {$vo.time|date="Y-m-d H:i:s",###}</i>
       <input type="hidden" name="time" value="{$vo.time}">
</div>
</td>
</tr>
</volist>
PHP 相关文章推荐
PHP和Mysqlweb应用开发核心技术 第1部分 Php基础-1 开始了解php
Jul 03 PHP
php数组的概述及分类与声明代码演示
Feb 26 PHP
php读取二进制流(C语言结构体struct数据文件)的深入解析
Jun 13 PHP
php把数据表导出为Excel表的最简单、最快的方法(不用插件)
May 10 PHP
destoon安装出现Internal Server Error的解决方法
Jun 21 PHP
2014年10个最佳的PHP图像操作库
Jul 14 PHP
如何让搜索引擎抓取AJAX内容解决方案
Aug 25 PHP
PHP处理二进制数据的实现方法
Jun 13 PHP
PHP删除数组中指定下标的元素方法
Feb 03 PHP
PHP封装cURL工具类与应用示例
Jul 01 PHP
详解PHP 7.4 中数组延展操作符语法知识点
Jul 19 PHP
PHP日期和时间函数的使用示例详解
Aug 06 PHP
ThinkPHP实现事务回滚示例代码
Jun 23 #PHP
Discuz批量替换帖子内容的方法(使用SQL更新数据库)
Jun 23 #PHP
PHP错误Parse error: syntax error, unexpected end of file in test.php on line 12解决方法
Jun 23 #PHP
ThinkPHP学习笔记(一)ThinkPHP部署
Jun 22 #PHP
ThinkPHP的URL重写问题
Jun 22 #PHP
分享一个php 的异常处理程序
Jun 22 #PHP
Yii2使用小技巧之通过 Composer 添加 FontAwesome 字体资源
Jun 22 #PHP
You might like
PHP 高手之路(三)
2006/10/09 PHP
PHP json_decode函数详细解析
2014/02/17 PHP
php简单日历函数
2015/10/28 PHP
jQuery 研究心得 取得属性的值
2007/11/30 Javascript
js对象关系图 方便dom操作
2012/03/18 Javascript
javascript强制点击广告的方法
2015/02/06 Javascript
javascript实现ecshop搜索框键盘上下键切换控制
2015/03/18 Javascript
artDialog+plupload实现多文件上传
2016/07/19 Javascript
js实现的xml对象转json功能示例
2016/12/24 Javascript
微信小程序中显示html格式内容的方法
2017/04/25 Javascript
使用Vue.js和Element-UI做一个简单登录页面的实例
2018/02/23 Javascript
小程序实现五星点评效果
2018/11/03 Javascript
Vue实现base64编码图片间的切换功能
2019/12/04 Javascript
JS代码触发事件代码实例
2020/01/02 Javascript
JS数组方法concat()用法实例分析
2020/01/18 Javascript
如何利用JavaScript编写一个格斗小游戏
2021/01/06 Javascript
Python中为feedparser设置超时时间避免堵塞
2014/09/28 Python
go和python变量赋值遇到的一个问题
2017/08/31 Python
python实现自主查询实时天气
2018/06/22 Python
opencv python 基于KNN的手写体识别的实例
2018/08/03 Python
python使用response.read()接收json数据的实例
2018/12/19 Python
Django中如何使用sass的方法步骤
2019/07/09 Python
Django继承自带user表并重写的例子
2019/11/18 Python
jupyter notebook tensorflow打印device信息实例
2020/04/20 Python
python3.6.5基于kerberos认证的hive和hdfs连接调用方式
2020/06/06 Python
python代码区分大小写吗
2020/06/17 Python
python爬虫中PhantomJS加载页面的实例方法
2020/11/12 Python
详解Css3新特性应用之过渡与动画
2017/01/10 HTML / CSS
Keds官方网站:购买帆布运动鞋和经典皮鞋
2016/11/12 全球购物
别名指示符是什么
2012/10/08 面试题
党员年终民主评议的自我评价
2013/11/05 职场文书
征兵宣传标语
2014/06/20 职场文书
党员群众路线对照检查材料
2014/08/31 职场文书
2014年妇委会工作总结
2014/12/10 职场文书
汽车销售助理岗位职责
2015/04/14 职场文书
Go 自定义package包设置与导入操作
2021/05/06 Golang