Javascript+XMLHttpRequest+asp.net无刷新读取数据库数据


Posted in Javascript onAugust 09, 2009
/**//// <summary> 
/// 生成带CDATA的节点 
/// </summary> 
/// <param name="xDocument">XmlDocument</param> 
/// <param name="elementName">元素名称</param> 
/// <param name="cdataValue">CDATA值</param> 
/// <returns>XmlElement</returns> 
public static XmlElement CreateXmlNodeCDATA(XmlDocument xDocument, string elementName, string cdataValue) 
{ 
try 
{ 
XmlElement xElement = xDocument.CreateElement(elementName); 
XmlCDataSection cdata = xDocument.CreateCDataSection(cdataValue); 
xElement.AppendChild(cdata); 
return xElement;//返回 
} 
catch (Exception ex) 
{ 
throw ex; 
} 
} 
Helper#region Helper 
/**//// <summary> 
/// 创建Ajax返回信息 
/// </summary> 
/// <param name="result"></param> 
private void CreateResponse(string result) 
{ 
XmlDocument xDocument = new XmlDocument(); 
XmlDeclaration declare = xDocument.CreateXmlDeclaration("1.0", "UTF-8", "yes"); 
XmlElement root = xDocument.CreateElement("root"); 
XmlElement eleResponse = CreateXmlNodeCDATA(xDocument, "response", result); 
root.AppendChild(eleResponse); 
xDocument.AppendChild(declare); 
xDocument.AppendChild(root); 
ResponseXML(xDocument); 
System.Web.HttpContext.Current.Response.End(); 
} 
/**//// <summary> 
/// 向页面输出xml内容 
/// </summary> 
/// <param name="xmlnode">xml内容</param> 
private void ResponseXML(XmlDocument xmlNode) 
{ 
System.Web.HttpContext.Current.Response.Expires = 0; 
System.Web.HttpContext.Current.Response.Clear(); 
System.Web.HttpContext.Current.Response.Cache.SetNoStore(); 
System.Web.HttpContext.Current.Response.ContentType = "text/xml"; 
System.Web.HttpContext.Current.Response.Write(xmlNode.OuterXml); 
System.Web.HttpContext.Current.Response.End(); 
} 
/**//// <summary> 
/// 生成带CDATA的节点 
/// </summary> 
/// <param name="xDocument">XmlDocument</param> 
/// <param name="elementName">元素名称</param> 
/// <param name="cdataValue">CDATA值</param> 
/// <returns>XmlElement</returns> 
public static XmlElement CreateXmlNodeCDATA(XmlDocument xDocument, string elementName, string cdataValue) 
{ 
try 
{ 
XmlElement xElement = xDocument.CreateElement(elementName); 
XmlCDataSection cdata = xDocument.CreateCDataSection(cdataValue); 
xElement.AppendChild(cdata); 
return xElement;//返回 
} 
catch (Exception ex) 
{ 
throw ex; 
} 
} 
Helper#region Helper 
/**//// <summary> 
/// 创建Ajax返回信息 
/// </summary> 
/// <param name="result"></param> 
private void CreateResponse(string result) 
{ 
XmlDocument xDocument = new XmlDocument(); 
XmlDeclaration declare = xDocument.CreateXmlDeclaration("1.0", "UTF-8", "yes"); 
XmlElement root = xDocument.CreateElement("root"); 
XmlElement eleResponse = CreateXmlNodeCDATA(xDocument, "response", result); 
root.AppendChild(eleResponse); 
xDocument.AppendChild(declare); 
xDocument.AppendChild(root); 
ResponseXML(xDocument); 
System.Web.HttpContext.Current.Response.End(); 
} 
/**//// <summary> 
/// 向页面输出xml内容 
/// </summary> 
/// <param name="xmlnode">xml内容</param> 
private void ResponseXML(XmlDocument xmlNode) 
{ 
System.Web.HttpContext.Current.Response.Expires = 0; 
System.Web.HttpContext.Current.Response.Clear(); 
System.Web.HttpContext.Current.Response.Cache.SetNoStore(); 
System.Web.HttpContext.Current.Response.ContentType = "text/xml"; 
System.Web.HttpContext.Current.Response.Write(xmlNode.OuterXml); 
System.Web.HttpContext.Current.Response.End(); 
}

关于Ajax的话题网上已经很多很多了,但好多都是利用控件开源框架来实现,特别是vs2008更是集成了好多ajax控件,把ajax的执行过程封装的严严实实。本人也用过这些框架和控件,感觉就是爽。但是近来心血来潮,想看看ajax到底是如何执行的,就想自己动手实现一下,正好也锻炼一下我的js水平。废话少说,如题,我们看一下执行过程。
1.这次实现总共用了两个页面:AjaxTest6.aspx和Ajax.aspx

其中AjaxTest6.aspx是发起请求的页面,Ajax.aspx获取AjaxTest6.aspx的请求,并进行处理的页面。

处理过程:(1)AjaxTest6.aspx发起http请求--->(2)Ajax.aspx获取url中的参数,根据此参数在数据库中执行查询操作并返回结果(数据集) --->(3)把返回的数据集进行xml处理通过response输出。注意现在输出数据的格式是xml ---(4)AjaxTest6.aspx获得Ajax.aspx输出xml数据并显示
2.AjaxTest6.aspx中的js代码

< script language="javascript" type="text/javascript"><!-- 
var xmlhttp; 
function createXMLHttpRequest() //为xmlhttp创建实例 
{ 
if(window.ActiveXObject) 
xmlhttp=new ActiveXObject('Microsoft.XMLHttp'); 
else if(window.XMLHttpRequest) 
{ 
xmlhttp=new XMLHttpRequest(); 
} 
} 
function stateRequest(vr1)//状态请求 
{ 
//alert('看来已经执行了stateRequest了'); 
createXMLHttpRequest();//引用xmlhttp实例 
xmlhttp.onreadystatechange=handleStateChange;//在请求状态发生改变时调用此方法 
xmlhttp.open("GET","Tools/Ajax.aspx?cateid="+vr1,true); 
xmlhttp.send(null); 
} 
function handleStateChange() 
{ 
//alert("看来已经执行了handleStateChange()了"); 
var divRet=document.getElementById("ret"); 
if(xmlhttp.readyState == 4) 
{ 
if(xmlhttp.status == 200) 
{ 
var text= GetText(); 
divRet.innerHTML=text; 
} 
} 
else 
divRet.innerHTML="<img src="\" src="\""images/loading.gif\" alt=\"数据加载中\" /><b>数据加载中</b>"; 
} 
function GetText() 
{ 
var xmlDoc=xmlhttp.responseXML; 
//alert(xmlDoc.toString()); 
if(xmlDoc == null) 
{ 
//alert("执行到这里了吗"); 
return "暂无数据!"; 
} 
var requestNode=xmlDoc.getElementsByTagName("response")[0]; 
var node=requestNode.firstChild.nodeValue; 
//alert(node); 
return node 
} 
// --></ script> 
< script language="javascript" type="text/javascript"><!-- 
var xmlhttp; 
function createXMLHttpRequest() //为xmlhttp创建实例 
{ 
if(window.ActiveXObject) 
xmlhttp=new ActiveXObject('Microsoft.XMLHttp'); 
else if(window.XMLHttpRequest) 
{ 
xmlhttp=new XMLHttpRequest(); 
} 
} 
function stateRequest(vr1)//状态请求 
{ 
//alert('看来已经执行了stateRequest了'); 
createXMLHttpRequest();//引用xmlhttp实例 
xmlhttp.onreadystatechange=handleStateChange;//在请求状态发生改变时调用此方法 
xmlhttp.open("GET","Tools/Ajax.aspx?cateid="+vr1,true); 
xmlhttp.send(null); 
} 
function handleStateChange() 
{ 
//alert("看来已经执行了handleStateChange()了"); 
var divRet=document.getElementById("ret"); 
if(xmlhttp.readyState == 4) 
{ 
if(xmlhttp.status == 200) 
{ 
var text= GetText(); 
divRet.innerHTML=text; 
} 
} 
else 
divRet.innerHTML="<img src="\" src="\""images/loading.gif\" alt=\"数据加载中\" /><b>数据加载中</b>"; 
} 
function GetText() 
{ 
var xmlDoc=xmlhttp.responseXML; 
//alert(xmlDoc.toString()); 
if(xmlDoc == null) 
{ 
//alert("执行到这里了吗"); 
return "暂无数据!"; 
} 
var requestNode=xmlDoc.getElementsByTagName("response")[0]; 
var node=requestNode.firstChild.nodeValue; 
//alert(node); 
return node 
} 
// --></ script>

说明:第一个函数createXMLHttpRequest用来创建XMLHttpRequest对象,关于该对象的详细 说明可以参考相关文章,现在只要明白当我们使用http请求发送数据,并使用xml来传递数据时要用到该对象,声明好后我们就可以在下面使用了
第二个函数是 用来发送http请求,一般情况下url都带有参数,通过 xmlhttp.open("GET","Tools/Ajax.aspx?cateid="+vr1,true);这句话我们可以看出来是向Ajax.aspx发送带参数的请求,Ajax.aspx捕获此参数,然后根据此参数在数据库中执行查询,具体处理过程我们下面细说。
在这个函数中我们还要注意一句话view plaincopy to clipboardprint?
xmlhttp.onreadystatechange=handleStateChange;//在请求状态发生改变时调用此方法
xmlhttp.onreadystatechange=handleStateChange;//在请求状态发生改变时调用此方法
因为xmlhttp对象在执行的过程中要分为几个阶段,每个阶段都对应不同的状态值:0 表示初始化,1表示正在加载,,2表示已加载,3表示交互中,4表示完成
所以上面那段代码表示只要xmlhttp的对象的状态发生变化就执行 handleStateChange方法,它具体实现的功能如下:
这个方法首先找到显示数据的个div标签(ret),然后判断xmlhttp的执行状态,当状态值变成4并且xmlhttp.status==200 (status是服务器的http状态码 200对应OK 404对应Not Found,如果你对xmlhttprequest对象不是很熟,建议你先熟悉一下)
显然当xmlhttp.onready==4并且xmlhttp.stauts==200说明已经在服务器端把所有的数据读出来了,此时数据放在一个xml文件中,这个xml文件是我们在服务器端生成的。
程序执行到现在已经万事俱备了,现在只欠从浏览器中读取这个xml文件了。这时要注意,也就是下面我们要说的最后一个函数GetText()
这个函数首先告诉浏览器我们要读取是个xml对象(当然你也可以设置成字符串格式的,例如:var xmlDoc=xmlhttp.responseText);我们之所以把数据集设置成xml格式是因为此时它可以被解析为一个DOM对象,这样我们在下面对它的处理就相当灵活了。
到现在我们已经把客户端的代码说完了,下面说一下服务器端的执行过程,这个过程是在Ajax.aspx的后置代码中完成的
1.首先我们在Page_Load事件中获取url中的参数,该参数从AjaxTest6.aspx中发送。然后根据此参数执行查询,具体代码我就不再详细解释,大家一看就明白,代码如下:
private static readonly string sql = "server=xxx;database=xxx;uid=sa;pwd=xxx"; 
protected void Page_Load(object sender, EventArgs e) 
{ 
string id=Request.QueryString["cateid"]; 
System.Threading.Thread.Sleep(2000); 
GetTitle(Convert.ToInt32(id)); 
} private DataTable GetLogs(int cateid) 
{ 
using (SqlConnection con = new SqlConnection(sql)) 
{ 
con.Open(); 
string select = "SELECT Id,CateId,LogTitle FROM Logs WHERE CateId = " + cateid; 
SqlDataAdapter sda = new SqlDataAdapter(select, con); 
DataTable dt = new DataTable(); 
sda.Fill(dt); 
con.Close(); 
return dt; 
} 
} 
public void GetTitle(int id) 
{ 
DataTable dt = GetLogs(id); 
StringBuilder sb = new StringBuilder(); 
if (dt != null && dt.Rows.Count>0) 
{ 
for (int i = 0; i < dt.Rows.Count;i++ ) 
{ 
sb.AppendLine(dt.Rows[i][2].ToString()); 
} 
CreateResponse(sb.ToString()); 
} 
} 
private static readonly string sql = "server=xxx;database=xxx;uid=sa;pwd=xxx"; 
2 protected void Page_Load(object sender, EventArgs e) 
3 { 
4 string id=Request.QueryString["cateid"]; 
5 System.Threading.Thread.Sleep(2000); 
6 GetTitle(Convert.ToInt32(id)); 
7 } 
8 
9 private DataTable GetLogs(int cateid) 
{ 
using (SqlConnection con = new SqlConnection(sql)) 
{ 
con.Open(); 
string select = "SELECT Id,CateId,LogTitle FROM Logs WHERE CateId = " + cateid; 
SqlDataAdapter sda = new SqlDataAdapter(select, con); 
DataTable dt = new DataTable(); 
sda.Fill(dt); 
con.Close(); 
return dt; 
} 
} 
public void GetTitle(int id) 
{ 
DataTable dt = GetLogs(id); 
StringBuilder sb = new StringBuilder(); 
if (dt != null && dt.Rows.Count>0) 
{ 
for (int i = 0; i < dt.Rows.Count;i++ ) 
{ 
sb.AppendLine(dt.Rows[i][2].ToString()); 
} 
CreateResponse(sb.ToString()); 
} 
}

说明:通过GetTitle(int id)可以看出,我把从库里读出的数据转换成字符串交给CreateResponse方法(这里可能不太合适,因为当数据量大时可能不太安全),下面就是关于把数据转化成xml文件的操作
Javascript 相关文章推荐
下拉菜单点击实现连接跳转功能的js代码
May 19 Javascript
Jquery Uploadify多文件上传带进度条且传递自己的参数
Aug 28 Javascript
一个网页标题title的闪动提示效果实现思路
Mar 22 Javascript
引用其它js时如何同时处理多个window.onload事件
Sep 02 Javascript
AngularJS 避繁就简的路由
Jul 01 Javascript
通过sails和阿里大于实现短信验证
Jan 04 Javascript
那些精彩的JavaScript代码片段
Jan 12 Javascript
使用vue开发移动端管理后台的注意事项
Mar 07 Javascript
详解async/await 异步应用的常用场景
May 13 Javascript
JQuery animate动画应用示例
May 14 jQuery
JavaScript JSON数据处理全集(小结)
Aug 15 Javascript
JS正则表达式验证密码强度
Mar 18 Javascript
javascript 当前日期加(天、周、月、年)
Aug 09 #Javascript
jQuery 解析xml文件
Aug 09 #Javascript
ext 代码生成器
Aug 07 #Javascript
JavaScript 的方法重载效果
Aug 07 #Javascript
JQuery 小练习(实例代码)
Aug 07 #Javascript
js正确获取元素样式详解
Aug 07 #Javascript
JavaScript 乱码问题
Aug 06 #Javascript
You might like
PHP 存取 MySQL 数据库的一个例子
2006/10/09 PHP
php垃圾代码优化操作代码
2010/08/05 PHP
php读取csv实现csv文件下载功能
2013/12/18 PHP
PHP中使用strpos函数实现屏蔽敏感关键字功能
2014/08/21 PHP
以文件形式缓存php变量的方法
2015/06/26 PHP
PHP单文件上传原理及上传函数的封装操作示例
2019/09/02 PHP
js保存当前路径(cookies记录)
2010/12/14 Javascript
Javascript 键盘事件的组合使用实现代码
2012/05/04 Javascript
JS脚本defer的作用示例介绍
2014/01/02 Javascript
jQuery仅用3行代码实现的显示与隐藏功能完整实例
2015/10/08 Javascript
JS实现选中当前菜单后高亮显示的导航条效果
2015/10/15 Javascript
JS对大量数据进行多重过滤的方法
2016/11/04 Javascript
JS实现旋转木马式图片轮播效果
2017/01/18 Javascript
使用Bootstrap和Vue实现用户信息的编辑删除功能
2017/10/25 Javascript
React Native基础入门之初步使用Flexbox布局
2018/07/02 Javascript
如何阻止小程序遮罩层下方图层滚动
2019/09/05 Javascript
python通过加号运算符操作列表的方法
2015/07/28 Python
python 的列表遍历删除实现代码
2020/04/12 Python
python中的turtle库函数简单使用教程
2018/07/23 Python
Python实现的远程文件自动打包并下载功能示例
2019/07/12 Python
Python 在OpenCV里实现仿射变换—坐标变换效果
2019/08/30 Python
TensorFlow tf.nn.max_pool实现池化操作方式
2020/01/04 Python
Python爬虫如何破解JS加密的Cookie
2020/11/19 Python
美国著名珠宝品牌之一:Jared The Galleria Of Jewelry
2016/10/01 全球购物
Linux面试经常问的文件系统操作命令
2015/11/05 面试题
会计实习生自我鉴定
2013/12/12 职场文书
网上开商店的创业计划书
2014/01/19 职场文书
《棉鞋里的阳光》教学反思
2014/04/24 职场文书
助学贷款贫困证明
2014/09/23 职场文书
土地转让协议书
2014/09/27 职场文书
幼儿园见习报告
2014/10/30 职场文书
国家助学金感谢信
2015/01/21 职场文书
自我评价优缺点范文
2015/03/11 职场文书
2015年六一儿童节活动方案
2015/05/05 职场文书
工作一年自我鉴定
2019/06/20 职场文书
MySQL悲观锁与乐观锁的实现方案
2021/11/02 MySQL