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版)
Oct 09 PHP
Windows2003 下 MySQL 数据库每天自动备份
Dec 21 PHP
PHP中通过ADO调用Access数据库的方法测试不通过
Dec 31 PHP
PHP下几种删除目录的方法总结
Aug 19 PHP
解析thinkphp中的M()与D()方法的区别
Jun 22 PHP
smarty模板引擎从配置文件中获取数据的方法
Jan 22 PHP
PHP中配置IIS7实现基本身份验证的方法
Sep 24 PHP
php处理单文件、多文件上传代码分享
Aug 24 PHP
Fleaphp常见函数功能与用法示例
Nov 15 PHP
详解php协程知识点
Sep 21 PHP
Laravel 类和接口注入相关的代码
Oct 15 PHP
浅谈PHP中的那些魔术常量
Dec 02 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语言认识上需要避免的10大误区
2014/06/12 PHP
php格式化日期实例分析
2014/11/12 PHP
php socket通信简单实现
2016/11/18 PHP
二级域名转向类
2006/11/09 Javascript
html5+javascript制作简易画板附图
2014/04/25 Javascript
DOM操作一些常用的属性汇总
2015/03/13 Javascript
JS基于VML技术实现的五角星礼花效果代码
2015/10/26 Javascript
javascript日期比较方法实例分析
2016/06/17 Javascript
PHP实现记录代码运行时间封装类实例教程
2017/05/08 Javascript
HTML5+JS+JQuery+ECharts实现异步加载问题
2017/12/16 jQuery
解决vue2.0 element-ui中el-upload的before-upload方法返回false时submit()不生效问题
2018/08/24 Javascript
jquery操作select常见方法大全【7种情况】
2019/05/28 jQuery
Vue两个版本的区别和使用方法(更深层次了解)
2020/02/16 Javascript
实例讲解Python中的私有属性
2014/08/21 Python
python监控文件或目录变化
2016/06/07 Python
Python实现将罗马数字转换成普通阿拉伯数字的方法
2017/04/19 Python
Python 异步协程函数原理及实例详解
2019/11/13 Python
python迭代器常见用法实例分析
2019/11/22 Python
python 读取数据库并绘图的实例
2019/12/03 Python
python json 递归打印所有json子节点信息的例子
2020/02/27 Python
通过python调用adb命令对App进行性能测试方式
2020/04/23 Python
Pytorch数据拼接与拆分操作实现图解
2020/04/30 Python
python模块如何查看
2020/06/16 Python
python 判断一组数据是否符合正态分布
2020/09/23 Python
python判断all函数输出结果是否为true的方法
2020/12/03 Python
Python爬虫之Selenium实现键盘事件
2020/12/04 Python
html5 乒乓球(碰撞检测)实例二
2013/07/25 HTML / CSS
HTML5地理定位实例
2014/10/15 HTML / CSS
荷兰家电购物网站:Expert.nl
2020/01/18 全球购物
C#中的验证控件有几种
2014/03/08 面试题
中专生职业生涯规划书范文
2014/01/10 职场文书
体育教师自我鉴定
2014/02/12 职场文书
新文化运动的基本口号
2014/06/21 职场文书
财务会计个人原因辞职信
2019/06/21 职场文书
Nginx限流和黑名单配置
2022/05/20 Servers
IDEA中sout快捷键无效问题的解决方法
2022/07/23 Java/Android