gate_s

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

先创建一个aspx页面编写一个客户端控件<input type="button" id="AjaxDemo"
value="AjaxDemo">
再aspx后台的页面编写一个简单的方法,代码如下:

1 [WebMethod] 
2 public static string ABC(string ABC) 
3 { 
4 return ABC; 
5 } 

必须声明为静态方法,并且它们必须使用 [WebMethod] 特性标注。但是在webservice里面不必是静态方法,它的对象可以是list、dataset、class对象等……
接下来就应该考虑怎么让前台的客户端控件调用到后台的方法了..这时jqury登场了..
在页面引入jquery类库
<script type="text/javascript"
src="JQuery/jquery-1.3.2-vsdoc2.js"></script>
在页面添加脚本代码如下: 

 1 <script type="text/javascript"> 
 2 $().ready( function() { 
 3   $("#AjaxDemo").click(function() { 
 4     $.ajax({ 
 5 type: "POST", 
 6         url: "Default.aspx/ABC", 
 7 data: "{'ABC':'test'}", 
 8 contentType: "application/json; charset=utf-8", 
 9 success: function(msg) {alert(msg); } 
10 }) 
11 }) 
12 } 
13 ) 
14 </script > 

这样就大功告成了!很多事情都是jquery类库帮我们做完了,我们这里讨论的是如何用,具体里面怎么实现,我们不关心!
jquery里还有很多像$.ajax这样的方法提供给我们使用.大家可以试试!
补充:注意要建3.5的项目,如果是2.0的话。配置文件会少很多引用的,如果你建的是2.0项目的话。建个3.5的。把3.5的配置文件覆盖到2.0的项目即可!
上面的代码如果成功之后弹出的是"{d:test}",是因为他返回的是字符串,我们可以将他改成返回json对象.
把jquery代码修改如下

 1 $().ready( 
 2 function() { 
 3 $("#AjaxDemo").click(function() { 
 4   $.ajax({ 
 5 type: "POST", 
 6       url: "Default.aspx/ABC", 
 7 data: "{'ABC':'test'}", 
 8 dataType: "json", 
 9 contentType: "application/json; charset=utf-8", 
10 success: function(msg) {alert(msg.d); } 
11 }) 
12 }) 
13 } 
14 }

我们设置他返回的数据是json对象,现在我们可以用返回的json对象,根据弹出来的d:test,我们可以很明显看到key是d,值是test,那我们利用返回的数据msg对象直接点d,就可以获得test的,修改了代码之后.现在弹出来就是test了..


详细出处参考:http://www.jb51.net/article/26976.htm

 

posted on 2013-12-04 15:38  gate_s  阅读(321)  评论(0编辑  收藏  举报