ext异步请求一个aspx/ashx/web service取得数据 服务端返回一个json 然后客户端接收并显示

这篇博客介绍了如何使用EXT与ASP.NET进行数据交互,通过一个简单的例子展示了EXT如何向ASP.NET的HttpHandler发送异步请求获取JSON数据,并在客户端显示。示例中,EXT GridPanel从ASHX处理程序获取数据,数据以JSON格式返回,然后在网页上展示。此外,文章提及实际开发中通常会将JavaScript代码分离到独立的JS文件,并提供了使用ASP.NET不同组件(如Web Service)处理请求的可能性。
摘要由CSDN通过智能技术生成
               

今天在论坛中有人问ext和asp.net是如何进行交互的,对于一个刚入门的新手来说,这个问题可能会使其比较迷惑,下面我写一个非常简单的例子来说明一下ext如何与asp.net来进行数据交互

 

Default.htm:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" >
  3. <head>
  4.     <title>Untitled Page</title>
  5.     <link rel="stylesheet" type="text/css" href="ext/resources/css/ext-all.css" />
  6.     <script type="text/javascript" src="ext/adapter/ext/ext-base.js"></script>
  7.     <script type="text/javascript" src="ext/ext-all.js"></script>  
  8. </head>
  9. <body>
  10. <div id="listContainer"></div>
  11. <script type="text/javascript">
  12. var store = new Ext.data.JsonStore({
  13.     url: 'DefaultHandler.ashx?method=getlist',
  14.     root: 'items',
  15.     remoteSort: true,
  16.     fields: [
  17.         'TestName',
  18.         'TestValue'
  19.             ],
  20.     listeners:{
  21.         load: function(store, records, options){
  22.                  grid.render();
  23.         },
  24.         loadexception: function(proxy, options, response){
  25.                 Ext.Msg.alert('Load data error!', response.responseText);
  26.         }
  27.     }
  28. });

  29. Ext.onReady(function(){
  30.     Ext.QuickTips.init();
  31.     store.load();
  32. });

  33. var listContainer=Ext.get("listContainer"); 
  34. var grid = new Ext.grid.GridPanel({
  35.     el: 'listContainer',
  36.     width:listContainer.getComputedWidth(),
  37.     autoHeight: true,
  38.     store: store,
  39.     disableSelection: false,
  40.     loadMask: true,
  41.     deferRowRender: false,
  42.     sm: new Ext.grid.RowSelectionModel({singleSelect:true}),
  43.     columns:[
  44.     {
  45.     header: 'name',
  46.     dataIndex: 'TestName',
  47.     sortable: true
  48.     },{
  49.     header: 'value',
  50.     dataIndex: 'TestValue',
  51.     sortable: true
  52.     }]
  53. });

  54. window.onresize=function(){
  55.         grid.setWidth(listContainer.getComputedWidth());
  56. };
  57. function Button1_onclick() {
  58.    //这里简单的来访问一下store中的数据
  59.    alert(store.data.items[0].data.TestName);
  60.    alert(store.data.items[0].data.TestValue);
  61. }

  62. </script>
  63.     <input id="Button1" type="button" value="display" onclick="return Button1_onclick()" />
  64. </body>
  65. </html>

DefaultHandler.ashx:

  1. <%@ WebHandler Language="C#" Class="DefaultHandler" %>

  2. using System;
  3. using System.Web;
  4. using System.Data;

  5. public class DefaultHandler : IHttpHandler {
  6.     
  7.     public void ProcessRequest (HttpContext context) {
  8.         string str = context.Request.QueryString["method"];
  9.         if (string.IsNullOrEmpty(str))
  10.         {
  11.             context.Response.Write("error!");
  12.             return;
  13.         }

  14.         switch (str)
  15.         { 
  16.             case "getlist":
  17.                 GetList(context);
  18.                 break;
  19.             //下边还有可以接着写.                 
  20.         }
  21.         context.Response.End();
  22.     }

  23.     public bool IsReusable {
  24.         get {
  25.             return false;
  26.         }
  27.     }

  28.     public void GetList(HttpContext context)
  29.     {
  30.         //这里模拟一个DataTable,实际应用中可能是去数据库里查询数据 
  31.         DataTable dt = new DataTable();
  32.         dt.Columns.Add("TestName"typeof(string));
  33.         dt.Columns.Add("TestValue"typeof(string));
  34.         for (int i = 0; i < 6; i++)
  35.         {
  36.             DataRow dr = dt.NewRow();
  37.             dr["TestName"] = "TestName" + i.ToString();
  38.             dr["TestValue"] = "TestValue" + i.ToString();
  39.             dt.Rows.Add(dr);
  40.         }
  41.         //将一个DataTable中的数据转成json,实际开发中可以用Newtonsoft.Json等 
  42.          //组件将集合类等,方便的转成json对象 
  43.         System.Text.StringBuilder sb = new System.Text.StringBuilder();
  44.         sb.Append("{items: [");
  45.         foreach (DataRow dr in dt.Rows)
  46.         {
  47.             sb.Append("{");
  48.             sb.AppendFormat("TestName:'{0}',TestValue:'{1}'", dr[0], dr[1]);
  49.             sb.Append("},");
  50.         }
  51.         //输出拼成的json 
  52.         context.Response.Write(sb.ToString().Trim(',') + "]}");
  53.     }
  54. }

例子完了.很容易吧.在实际的开发中往往会把页面中的javascript脚本单独写到一个js文件中.这样会有很多的好处.

本示例中我用ashx(HttpHandler)文件来处理客户端请求,你也可以用aspx,web services等等.

           

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值