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 向右侧拉菜单实现代码,测试使用中
Nov 03 PHP
php网站地图生成类示例
Jan 13 PHP
THINKPHP内容分页代码分享
Jan 14 PHP
使用新浪微博API的OAuth认证发布微博实例
Mar 27 PHP
php正则表达式学习笔记
Nov 13 PHP
php 输出json及显示json中的中文汉字详解及实例
Nov 09 PHP
thinkPHP简单实现多个子查询语句的方法
Dec 05 PHP
Thinkphp框架中D方法与M方法的区别
Dec 23 PHP
Laravel5.* 打印出执行的sql语句的方法
Jul 24 PHP
Laravel 加载第三方类库的方法
Apr 20 PHP
在Laravel5中正确设置文件权限的方法
May 22 PHP
laravel model 两表联查示例
Oct 24 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
getimagesize获取图片尺寸实例
2014/11/15 PHP
PHP静态成员变量和非静态成员变量详解
2017/02/14 PHP
PHP实现微信提现(企业付款到零钱)
2019/08/01 PHP
node.js中使用socket.io的方法
2014/12/15 Javascript
window.location.reload 刷新使用分析(去对话框)
2015/11/11 Javascript
js实现滚动条滚动到某个位置便自动定位某个tr
2021/01/20 Javascript
jQuery的图片轮播插件PgwSlideshow使用详解
2016/08/11 Javascript
jQuery动态改变多行文本框高度的方法
2016/09/07 Javascript
jQuery右下角悬浮广告实例
2016/10/17 Javascript
ionic进入多级目录后隐藏底部导航栏(tabs)的完美解决方案
2016/11/23 Javascript
nodeJS微信分享
2017/12/20 NodeJs
利用npm 安装删除模块的方法
2018/05/15 Javascript
解决vue props 拿不到值的问题
2018/09/11 Javascript
vue头部导航动态点击处理方法
2018/11/02 Javascript
jQuery ajax仿Google自动提示SearchSuggess功能示例
2019/03/28 jQuery
借助云开发实现小程序短信验证码的发送
2020/01/06 Javascript
原生js实现瀑布流效果
2020/03/09 Javascript
js+canvas实现转盘效果(两个版本)
2020/09/13 Javascript
python中django框架通过正则搜索页面上email地址的方法
2015/03/21 Python
Python守护进程和脚本单例运行详解
2017/01/06 Python
Python简单定义与使用字典dict的方法示例
2017/07/25 Python
Python3简单实例计算同花的概率代码
2017/12/06 Python
python Tcp协议发送和接收信息的例子
2019/07/22 Python
pip安装提示Twisted错误问题(Python3.6.4安装Twisted错误)
2020/05/09 Python
python使用matplotlib绘制折线图的示例代码
2020/09/22 Python
python调用百度API实现人脸识别
2020/11/17 Python
HTML5 微格式和相关的属性名称
2010/02/10 HTML / CSS
美国最流行的男士时尚网站:Touch of Modern
2018/02/05 全球购物
银行财务部实习生的自我鉴定
2013/11/27 职场文书
大学教师师德师风演讲稿
2014/08/22 职场文书
违反交通安全法检讨书
2014/10/24 职场文书
2014年法制宣传日活动方案
2014/11/02 职场文书
幼儿园辞职信范文
2015/02/27 职场文书
考博导师推荐信范文
2015/03/27 职场文书
入党积极分子培养人意见
2015/06/02 职场文书
初中班长竞选稿
2015/11/20 职场文书