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 相关文章推荐
PHP5/ZendEngine2的改进
Oct 09 PHP
AJAX for PHP简单表数据查询实例
Jan 02 PHP
php开启安全模式后禁用的函数集合
Jun 26 PHP
关于PHP中Object对象的笔记分享
Jun 28 PHP
SESSION信息保存在哪个文件目录下以及能够用来保存什么类型的数据
Jun 17 PHP
基于php常用正则表达式的整理汇总
Jun 08 PHP
ThinkPHP登录功能的实现方法
Aug 20 PHP
php合并数组中相同元素的方法
Nov 13 PHP
php插入含有特殊符号数据的处理方法
Nov 24 PHP
PHP基于phpqrcode类生成二维码的方法详解
Mar 14 PHP
PHP之认识(二)关于Traits的用法详解
Apr 11 PHP
在Laravel中使用MongoDB的方法示例
Nov 11 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 数据结构 算法 三元组 Triplet
2011/07/02 PHP
推荐一款PHP+jQuery制作的列表分页的功能模块
2014/10/14 PHP
PHP PDOStatement::fetchObject讲解
2019/02/01 PHP
laravel中数据显示方法(默认值和下拉option默认选中)
2019/10/11 PHP
开发插件的两个方法jquery.fn.extend与jquery.extend
2013/11/21 Javascript
使用js获取图片原始尺寸
2014/12/03 Javascript
做web开发 先学JavaScript
2014/12/12 Javascript
JavaScript分秒倒计时器实现方法
2015/02/02 Javascript
Webwork 实现文件上传下载代码详解
2016/02/02 Javascript
浅谈jQuery绑定事件会叠加的解决方法和心得总结
2016/10/26 Javascript
详解angular element()方法使用
2017/04/08 Javascript
JavaScript模拟文件拖选框样式v1.0的实例
2017/08/04 Javascript
详解vue axios二次封装
2018/07/22 Javascript
jQuery 实现扁平式小清新导航
2020/07/07 jQuery
Vue实现背景更换颜色操作
2020/07/17 Javascript
[15:15]教你分分钟做大人:狙击手
2014/10/30 DOTA
[04:26]2014DOTA2西雅图国际邀请赛 总决赛TOPPLAY
2014/07/22 DOTA
Python使用matplotlib实现的图像读取、切割裁剪功能示例
2018/04/28 Python
基于Python列表解析(列表推导式)
2018/06/23 Python
python tkinter界面居中显示的方法
2018/10/11 Python
TensorFlow基于MNIST数据集实现车牌识别(初步演示版)
2019/08/05 Python
python机器学习实现决策树
2019/11/11 Python
PyCharm如何导入python项目的方法
2020/02/06 Python
python dir函数快速掌握用法技巧
2020/12/09 Python
纯CSS3实现8组超炫酷鼠标滑过图片动画
2016/03/16 HTML / CSS
很酷的小工具和电子产品商城:GearBest
2016/11/19 全球购物
台湾乐天市场:日本No.1的网路购物网站
2017/03/22 全球购物
JBL英国官网:JBL UK
2018/07/04 全球购物
生产部岗位职责范文
2014/02/07 职场文书
服务标语口号
2014/07/01 职场文书
倡议书格式
2014/08/30 职场文书
财务工作疏忽检讨书
2014/09/11 职场文书
篮球赛闭幕式主持词
2015/07/03 职场文书
公司客户答谢酒会祝酒词
2015/08/11 职场文书
部门主管竞聘书
2015/09/15 职场文书
2016寒假假期总结
2015/10/10 职场文书