jquery的推出确实解决了大部分程序员都感到头痛的事情,无论是对于UI的访问和处理,还是在一系列的远程访问等方面都有了很大的改善,或者说是一种解放。以往对于远程访问,对于跨域调用,如果你还在为构建ajax所烦恼,还在为不同的浏览器不兼容而郁闷,那么jquery无疑对于大家来说是一个不小的进步,因为他能帮你解决你的烦恼,使你有更多的时间放置在对于业务逻辑的处理上。本文就是基于一个跨域访问的需求的简单实现,功能是实现本地与远程服务器的信息交换。
jquery的$.get(),$.post(),以及更为基础的$.ajax()都在对于远程信息的访问和投送上提供了便利,但是对于跨域访问往往不能很好的胜任,那么对于跨域的信息交互我们就可以通过jquery.getjson()或者是$.getjson()来实现。调用方式:
jQuery.getJSON(url,function(data) {
//
});
});
实例:登录,提交远程机器验证
//本例的URL地址为本地地址,但是也设置为一可用的远程地址
前台:$(document).ready(function(){
$("#btnLogin").bind("click",function()
{
jQuery.getJSON("Key.aspx?name='"+$("#username").val()+"'+pwd='"+$("#passwords").val()+"'&callback=?",function(data) {
alert("服务器端返回结果为:"+data);
$("#result").text("服务器端返回结果为:"+data);
});
}
);
});
$("#btnLogin").bind("click",function()
{
jQuery.getJSON("Key.aspx?name='"+$("#username").val()+"'+pwd='"+$("#passwords").val()+"'&callback=?",function(data) {
alert("服务器端返回结果为:"+data);
$("#result").text("服务器端返回结果为:"+data);
});
}
);
});
后台:
string name = Request.QueryString["name"];
string pwd= Request.QueryString["pwd"];
if (valdate(name,pwd) )
{
string fun = (Request.QueryString["callback"]);
//string fun = (Request.QueryString["theback"]); //自定义回调方法
Response.Write(fun+"('登陆成功!')");
Response.Flush();s
}
if (valdate(name,pwd) )
{
string fun = (Request.QueryString["callback"]);
//string fun = (Request.QueryString["theback"]); //自定义回调方法
Response.Write(fun+"('登陆成功!')");
Response.Flush();s
}
上例简单的实现了在某前台页面与异地信息交换,要注意的是在getjson()的访问中callback的参数不能漏掉,且该参数要设置为callback=?的方式,因为jquery库在调用的时候会动态的给callback赋值,大概为jsonp1298712852382,那么后台在回调的时候就可以通过调用该方法并输出到页面。上述只是简单对于getJson()异域调用的说明,但是在项目应用中我们还会有更加针对性的业务调用,也就是说对于某个业务调用我们会采用固定的回调来操作返回的信息,如果有机会,就下次再记吧。
本文是自己项目中的小心得,记下备个案以备日后查找。欢迎大家拍砖。呵呵!