开讲前,先说下网上,大部分的关于这方面的博文或者其他什么的,就我自己的感觉,第一说得不详细,第二语言不能很好的被初学者了解。

我这篇博文的标题之所以用了三句,是为了方便其他人好查找;

这里介绍的方法有什么用呢? 使用它,就可以无闪刷新页面,并且从数据库获取实时改变的数据反馈回界面,显示出来!是不是很爽,的确。

废话不多,开讲,请注意我的代码的注释,里面详说!


连接的前台连接的php文件:

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<script>
var xmlHttp;
//创建xmlHttpRequest对象 //下面将会针对不同的浏览器创建对象,也是两个if语句的作用
/*
在firefox,opera,safiar,IE7.0,IE8.0(我所知道的window对象有这个属性
的浏览器)这些浏览器中,window是有XMLHttpRequest这个属性的,而IE6.0,5.5都是没有的,
IE6.0或5.5是没有这个属性的,使用window.ActiveXObject替代。
*/
function createXmlHttpObject()
{
if(window.XMLHttpRequest)
{
xmlHttp = new XMLHttpRequest(); //创建对象
}else if(window.ActiveXObject)
{
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); //创建对象
}
return xmlHttp;//创建成功,返回
} function send()//这个函数用来和后台的服务器文件连接,可以是asp,php,我这里用php说明
{
xmlHttp = createXmlHttpObject();//调用上面的创建对象函数 var url = "33.php"; //这里的url变量,用来存储你,你自己想要连接的文件路径,我这里比较简单是因为33.php和我这个php在同一目录 if(xmlHttp)//判读,如果对象不为空,进入下面
{
xmlHttp.onreadystatechange = callback;
/*注册回调函数名,这里可以看作是函数的调用,onreadystatechange是 XMLHttpRequest的一个属性,用来检测当前状态
当状态改变,就会触发函数,所有,如果只需要函数名,不要加括号*/ //下面的open 函数,顾名思义,打开,用来连接你上面的url文件
//设置连接信息:
//第一个参数:表示http的请求方式,主要使用get和post
//第二个参数:表示请求的URL地址,get方式的请求参数也在URL中
//第三个参数:表示采用同步还是异步方式进行交互,true表示异步交互
xmlHttp.open("GET", url, true); //下面的send函数,这个是对象自身有的方法,不是这里定义的send,它用来发送命令,发送什么呢,open的命令
//发送数据,开始和服务器端进行交互
//同步方式下,send语句会在服务器端返回数据后才执行
//异步方式下,send语句会立即执行
xmlHttp.send(null);
}else{
alert("出错,请重新尝试!");
return;
}
} //回调函数,就是刚才定义的函数,用来获取从服务器文件,asp或者php或者其他返回的信息
function callback()
{
var mInt = ;//移动像素,这部分是用来验证的
var _obj = document.getElementById("pic");
var _text = document.getElementById("textview");
var _x = parseInt(_obj.style.left);
var _y = parseInt(_obj.style.top);
/*if (_x < mInt)
_y -= mInt;
else if (_y > mInt)
_x -= mInt;*/
_obj.style.left = _x + "px";
_obj.style.top = _y + "px";
//判断对象的状态是交互完成
if(xmlHttp.readyState == )
//这里是状态判断有0~4,百度很多详解,4代表,连接上了并且获得了数据
{
//判断http的交互是否成功
if(xmlHttp.status==)
{
//获取服务器端返回的数据
var xmlDoc = xmlHttp.responseXML;
//这里把返回的数据以XML的格式存到变量中。
//还有一种返回式以字符串的形式返回,responseText,这个可以用下标法逐个输出,但是注意,逐个输出的是字符,
//也就是说,你想要的一个字符串会被拆成几份 //这里的 getElementsByTagName("time")[0].childNodes[0].nodeValue; 是采用遍历数的方法逐个输出数据
//getElementsByTagName 是通有的(" ")这里写的是你链接的文件里面的标签名,等下介绍再详说,[0]也是要写的
//.childNodes[0].nodeValue; 这块也是通有的,意思是获取值
_x = xmlDoc.getElementsByTagName("time")[].childNodes[].nodeValue;
_y = xmlDoc.getElementsByTagName("in")[].childNodes[].nodeValue;
_text.innerHTML = "_x=" + _x + ",_y" + _y; }else{
alert(xmlHttp.statusText);
}
}
} function refresh()
{ setInterval("send()",); //定时刷新,循环调用,上面的send函数。、,时间间隔为0.1秒。 }
</script>
</head>
<body onLoad="refresh()">//这里调用
<div id='pic' style='position:absolute;left:380px;top:200px;'><img width='' height='' src='C:\Users\Administrator.PC--20130918KZN\Desktop\9.png' /><font id="textview"></font></div> </body>
</html>

后台被连的php:

 <?php
header('Content-Type: text/xml');
header("Cache-Control: no-cache, must-revalidate");
//上面两句是PHP 文档的 content-type 被设置为 "text/xml" ,PHP 文档被设置为 "no-cache",以防止缓存
$time = date('Y-m-d h:i:s',time()); $information="XXXX"; echo '<?xml version="1.0" encoding="ISO-8859-1"?><person>';//这句必须有,没的话,输不出东西
echo "<time>" .$time. "</time>";
//这里的<time> </time>标签就是刚才(" "),里面要填的,通过这方式,分别输出、获取不同的值,下同
echo "<in>" .$information. "</in>";
echo "</person>";//和上面的person完成一个一对 ?>

由于我自己是通过输出系统时间来测试的,测试成功后是,看到时间的。

如何用 ajax 连接mysql数据库,并且获取从中返回的数据。ajax获取从mysql返回的数据。responseXML分别输出不同数据的方法。的更多相关文章

  1. ruby使用DBI连接MySQL数据库发生异常:in `error': Can't connect to MySQL server on 'localhost' (10061) (DBI::DatabaseError)

    Ruby使用DBI连接MySQL数据库一般为: require "dbi" dbh = DBI.connect("dbi:Mysql:test:localhost&quo ...

  2. java中用activiti插件连接mysql数据库,自动建表过程中,在配置mysql架包路径“org.activiti.engine.ActivitiException: couldn't check if tables “

    java中用activiti插件连接mysql数据库,出现错误: org.activiti.engine.ActivitiException: couldn't check if tables are ...

  3. 最近使用Navicat for MySQl访问远程mysql数据库,出现报错,显示“2003- Can't connect MySQL Server on 'localhost'(10038)“。

    优先考虑mysql数据库是否开启 1.先看报错窗口.   通过百度,最终找到的原因是:远程3306端口未对外开放. 于是下面进行远程3306端口开放操作.   首先远程连接服务器,点击“开始”-“管理 ...

  4. PDO连接mysql数据库

    1.PDO简介 PDO(PHP Data Object) 是PHP 5 中加入的东西,是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接 ...

  5. Android如何连接MySQL数据库

    Android开发中,大多数连接到远程MySQL数据库的方法是加入特定的Service到代码中.由于MySQL通常是和PHP一起使用的,最简单以及最常见的方法是写PHP脚本管理数据连接,以及从Andr ...

  6. python如何连接mysql数据库

    先花点时间来说说一个程序怎么和数据库进行交互1.和数据库建立连接2.执行sql语句,接收返回值3.关闭数据库连接使用MySQLdb也要遵循上面的几步.让我们一步步的进行. 1.MySQL数据库要用My ...

  7. Windows下C/C++连接mysql数据库的方法

    步骤 安装MySQL数据库 项目属性页->C/C++->常规->附加包含目录:xxx\mysql Server 5.6\include 项目属性页->链接器->常规-&g ...

  8. SSM项目实现连接两个mysql数据库

    最近做项目需要用到另一个数据库的内容,多方查找终于实现了功能. 我们都知道,在SSM框架中,我们在applicationContext.xml配置文件中添加数据源就可以实现数据库增删改查,但是只能连接 ...

  9. c# 连接Mysql数据库

    mysql.data.dll下载_c#连接mysql必要插件 全部版本下载:http://hovertree.com/h/bjaf/0sft36s9.htm mysql.data.dll是C#操作MY ...

随机推荐

  1. 【转】关于FLASH中图文混排聊天框的小结

    原文链接 图文混排也是FLASH里一个很古老的话题了,我们不像美国佬那样游戏里面聊天框就是聊天框,全是文字干干净净,也不像日本人发明了并且频繁地使用颜文字.不管是做论坛.做游戏,必定要实现的一点就是带 ...

  2. 【转】【10g SQL新特性】q-quote使用

    转自:http://blog.chinaunix.net/uid-7655508-id-3684042.html 转发只为留存学习 在Oracle中,字符串的字面量如果含有单引号,那么必须转义,而且转 ...

  3. 初步认识Less

    LESS 是一个流行的样式表语言,它提供了 CSS3 也未曾实现的多种功能,让您编写 CSS 更加方便,更加直观.LESS 已经被广泛使用在多种框架中 ( 例如:BootStrap).本文将介绍 LE ...

  4. redis配置文件英译汉

    # By default Redis asynchronously dumps the dataset on disk. This mode is # good enough in many appl ...

  5. ubuntu1404安装搜狗输入法后出现黑框的问题

    1.安装xcompmgr   sudo apt-get install xcompmgr 2.设置xcompmgr自动启动 mkdir-/.config/autostart vim xcompmgr. ...

  6. Css 动画的回调

    在做项目中经常会遇到使用动画的情况.以前的情况是用js写动画,利用setTimeout函数或者window.requestAnimationFrame()实现目标元素的动画效果.虽然后者解决了刷新频率 ...

  7. [转] Agile Software Development 敏捷软件开发

    原文作者:kkun 原文地址:http://www.cnblogs.com/kkun/archive/2011/07/06/agile_software_development.html 敏捷是什么 ...

  8. 【读书笔记】Asp.Net MVC 上传图片到数据库(会的绕行)

    之前上传图片的做法都是上传到服务器上的文件夹中,再将url保存到数据库.其实在MVC中将图片上传到数据库很便捷的事情,而且不用去存url了.而且这种方式支持ie6(ie6不支持jquery自动提交fo ...

  9. MySQL mysqlslap压测

    200 ? "200px" : this.width)!important;} --> 介绍 mysqlslap是mysql自带的一个性能压测工具:mysqlslap用于和其 ...

  10. [ASP.NET MVC 小牛之路]11 - Filter

    Filter(筛选器)是基于AOP(面向方面编程)的设计,它的作用是对MVC框架处理客户端请求注入额外的逻辑,以非常简单优美的方式实现横切关注点(Cross-cutting Concerns).横切关 ...