各种AJAX方法的使用比较Word文档格式.docx
《各种AJAX方法的使用比较Word文档格式.docx》由会员分享,可在线阅读,更多相关《各种AJAX方法的使用比较Word文档格式.docx(17页珍藏版)》请在冰豆网上搜索。
![各种AJAX方法的使用比较Word文档格式.docx](https://file1.bdocx.com/fileroot1/2022-12/16/4fa3b364-0bc7-471e-bce4-53da7f1d6646/4fa3b364-0bc7-471e-bce4-53da7f1d66461.gif)
接下来,我们还需要在一个ASPX页面中,用ScriptManager为它生成客户端的代理脚本:
<
asp:
ScriptManagerID="
ScriptManager1"
runat="
server"
>
<
Services>
ServiceReferencePath="
/WebService1.asmx"
InlineScript="
true"
/>
/Services>
/asp:
ScriptManager>
说明:
InlineScript="
的设置并不是必须的,只是为了让我们看到ScriptManager到底生成了什么代码。
从截图可以看到,除了引入了二个必要的AJAX客户端类库外,还在客户端为WebService1生成了代理脚本。
有了这些代码后,我们可以用下面的JavaScript代码调用服务端:
functionCall_Add(){
WebService1.Add(1,2,ShowResult);
}
functionShowResult(result){
document.getElementById("
output"
).value=result;
前面这个示例太简单了,再来个参数复杂的示例吧,还是从先服务端开始,先定义一个参数类型:
publicclassCustomer
{
publicstringName{get;
set;
publicintAge{get;
publicstringAddress{get;
publicstringTel{get;
publicstringEmail{get;
WebSerice的代码:
[WebMethod]
publicstringAddCustomer(Customercustomer)
if(customer==null)
return"
customerisnull."
;
//简单地返回一个XML字符串。
//告诉客户端:
服务端收到了什么样的数据。
returnXmlHelper.XmlSerialize(customer,Encoding.UTF8);
仍然借用前面的ScriptManager设置,来看JavaScript的调用代码:
functionCall_AddCustomer(){
varcustomer={Name:
txtName"
).value,
Age:
txtAge"
Address:
txtAddress"
Tel:
txtTel"
Email:
txtEmail"
).value};
WebService1.AddCustomer(customer,ShowResult);
基本上还是与服务端的编码方式差不多,先创建一个customer对象,再传给调用方法。
在那个年代之前(2006年),原始的AJAX实现方式非常复杂,而这种方法让客户端代码风格看起来与服务端十分类似,这确实是个了不起的设计思路。
然而各种技术一直在改进中,现在,2013年,当我们再来回顾这种方法时,会发现它确实存在一些不完善的地方,以至于现在使用这种方法的人很少了,这种技术被淘汰了!
其实我们可以从另一外角度来思考:
如果这种方法真的很优秀,它就不可能被淘汰,正是因为有更优秀的方法出现了,它才会遭到淘汰的命运。
新技术的改进方向
前面介绍的那种AJAX方法能让客户端的调用代码与服务端的代码风格基本一致,看似很完美的方法为什么会被淘汰了呢?
我来分析一下这种开发方法的缺陷:
1.前端代码不够独立,必须要在页面中添加引用之后才能调用服务端,这其实是一种强耦合。
2.出现了更优秀的前端框架能简少获取调用参数的代码量。
继续阅读本文,您会发现后面我将要介绍的新方法都朝着解决这些缺陷在努力,这些缺陷也算是指出了新技术的改进方向。
由于前端在调用服务端时,需要事先生成代理脚本,这种设计会阻碍前端代码的封装性。
您可以想象一下:
如果客户端需要一个【获取当前用户信息】的功能,而这个功能必须由服务端实现的,此时,我们就只能指望服务端为客户端生成代理类来调用这个功能了。
但这个功能太有用,许多地方都需要使用,您是不是会想将它提取到一个公用的文件中?
遗憾的是:
就算您将这段调用代码提取到一个公共的public.js文件中,每个页面在引用public.js后,并不能调用【获取当前用户信息】功能,因为代理脚本并不一定存在,public.js中的代码还不能运行起来。
怎么办?
答:
为每个引用public.js的页面,再添加ScriptManager引用那个服务吧。
共用性越高的功能,您会发现这种引用代码的重复度也就越高。
简单说来,这种方法将WebService,aspx页面,js代码耦合在一起了。
由于耦合,您越用越发现越麻烦。
这种生成代理脚本的开发方法虽然能让前端代码与后端代码的风格一致,然而,前端与后端毕竟不是同一种开发语言,它们要关注的方向也是不一样的。
尤其是当更优秀的前端框架出现后,这种后端包办前端的方法不仅让后端与前端耦合在一起,而且还限制了前端技术的发展,最终只能是被抛弃的命运!
现在请记住我们为了提交一个Customer信息写了什么样的代码:
varcustomer={Name:
我在介绍第四代技术时,您会发现它们消失了!
第二代技术:
jQuery直接调用WebService
随意jQuery前端类库的流行,另一种新的开发方法也开始流行起来了。
HTTP调用本来是个很简单很透明的技术,只要指定一个URL,构造一个请求体就可以了,前端代理脚本的方法将这个过程封装了起来,由于它的封装制造了耦合并限制前端的发展。
新的AJAX技术只能突破这个限制,舍弃这些代理脚本,直接调用后端代码。
下面的示例代码还是基于前面的示例,唯独不同的是:
不是需要代理类,现在是直接调用服务端。
由于后端的服务代码没有改变,我也就不再贴出它们了,而且页面也不需要再添加什么引用,我们就直接看前端代码好了:
$.ajax({
type:
"
POST"
url:
"
/WebService1.asmx/Add"
contentType:
application/json"
data:
{a:
1,b:
2}"
dataType:
'
json'
success:
function(result){
$("
#output"
).val(result.d);
});
这段代码也能调用服务端的Add方法。
由于服务端采用JSON数据格式,所以需要在客户端多指定一些请求头,而这些事情以前是由代理脚本完成的。
虽然现在的代码稍微多一点,但是耦合没有了,更便于提取一些公用代码了。
事实上,如果您一直用这种方法调用WebService,那么jQuery提供了设置默认参数的功能,我们可以利用这个特性减少代码量。
还是再来看一下前面那个复杂的参数类型的前端调用代码吧:
#txtName"
).val(),
#txtAge"
#txtAddress"
#txtTel"
#txtEmail"
).val()};
varjsonStirng=$.toJSON({customer:
customer});
/WebService1.asmx/AddCustomer"
jsonStirng,
function(result){
主要的代码还是一样的,集中在获取调用参数,但是要转成JSON格式。
再次一次提醒:
不要老是盯着要指定一大堆的jQuery参数,它们可以通过设置默认值的方式解决。
我之所以现在不想让它们消失,是因为后面还有更好的方法,先留着它们吧。
这种方法不仅可以用于调用WebService,也可以调用WCF(basicHttpBinding),毕竟它们都使用HTTP协议。
不过,WCF还有一堆烦人的配置要设置,但这不是jQuery的问题,这是服务端框架的缺陷。
第三代技术:
更简单的数据格式
前面我们看到了可以利用jQuery调用WebService,不过JSON的转换过程感觉有些多余,浏览器的提交就没有这个转换步骤嘛。
有时看到一些家伙们着还在JavaScript中拼接JSON字符串,我非常反感,所以这次的示例代码并没有给那种方法抹黑,我采用了一个JSON插件。
第三代技术就完美地解决了输入输出必须采用JSON问题,而且解决了POST的限制。
由于这次变革改变了数据格式,所以服务端也发生了改变,新的框架解决了这些问题,例如:
ASP.NETMVC框架,MyMVC框架都支持这个开发方式。
来看一下现在服务端的代码:
[Action]
publicintAdd(inta,intb)
这种AJAX技术没有与客户端的任何耦合,只要知道一个URL就可以调用了。
来看客户端的代码吧:
/AjaxDemo/Add.cspx"
{a:
2},
).val(result);
//第二个调用
/AjaxDemo/AddCustomer.cspx"
customer,
type:
并不是必须的,您也可以把它们改成GET方式提交。
如果您此时用Fiddler查看请求内容,会发现请求的数据采用的是key=value&
key=vlaue的格式,与浏览器的方式一致。
由于没有JSON数据格式的限制,现在的参数项简单了。
现在再看上面这段代码,主要代码量在哪里?
是不是在获取调用参数那块?
继续阅读本文,我要让它消失。
第四代技术:
直接提交表单
我们来看一下示例用的表单:
formid="
form1"
action="
method="
post"
p>
b>
新增客户资料<
/b>
/p>
span>
Name:
/span>
inputtype="
text"
name="
Name"
value="
abc"
br/>
Age:
Age"
20"
Address:
Address"
武汉"
Tel:
Tel"
12345678"
Email:
Email"
test@"
submit"
btnAddCustomer"
保存客户资料"
/form>
前面用了三种方法在提交这个表单,下面我们再来看一下更简单的提交方式:
scripttype="
text/javascript"
$(function(){
//只需要下面这个调用就可以将表单改成异步提交方式!
#form1"
).ajaxForm({
});
/script>
为了更清楚展示这种方法,我甚至把script标签也贴出来了。
如果您用过jQuery就应该能发现,真正的代码就只有ajaxForm的那个调用。
ajaxForm是jQuery.form插件提供的功能。
服务端的代码继续使用前面示例的代码,所以就不贴出了。
再对比前面几种AJAX的实现方法,您说哪种方法最简单?
您对第四代AJAX技术有兴趣吗?
我还为它设计了三种不同场景下的示例,让您感受它的强大与简单,请继续阅读。
多submit按钮的提交(用jQuery.form实现)
您认为前面的示例太简单了,是吗?
可能有人会说,如果有多个submit按钮,这种方法就不合适了,我要响应每个按钮,为它们指定不同的URL!
真是这样吗?
看下面的示例吧。
相关的前端代码如下:
/AjaxTestAutoAction/submit.cspx"
Input:
input"
style="
width:
300px"
FishLi"
Output:
id="
readonly="
readonly"
Base64"
转换成Base64编码"
&
nbsp;
Md5"
计算md5"
Sha1"
计算sha1"
$(function(){
).ajaxForm(function(result){
服务端代码:
publicclassAjaxTestAutoAction
[Action]
publicstringBase64(stringinput)
returnConvert.ToBase64String(Encoding.Default.GetBytes(input));
publicstringMd5(stringinput)
byte[]bb=Encoding.Default.GetBytes(input);
byte[]md5=(newMD5CryptoServiceProvider()).ComputeHash(bb);
returnBitConverter.ToString(md5).Replace("
-"
string.Empty);
publicstringSha1(stringinput)
byte[]sha1=(newSHA1CryptoServiceProvider()).ComputeHash(bb);
returnBitConverter.ToString(sha1).Replace("
代码仍然很清晰:
1.服务端定义三个方法,对应三个submit按钮。
2.前端还是只调用一个ajaxForm解决所有问题。
这种方法就是由前端的jQuery,jQuery.form以及服务端的MyMVC框架共同实现的。
想像一下利用其它三种方法需要多少代码吧。
批量输入控件的提交(用jQuery.form实现)
再来展示另一个现实的例子,批量输入界面的提交。
页面表单代码如下:
/AjaxDemo/BatchAddCustomer.cspx"
批量新增客户资料<
tableborder="
0"
tr>
td>
Name<
/td>
Age<
Address<
Tel<
Email<
/tr>
class="
A1"
test1@"
A2"
上海"
22222222"