ext和asp.net交互

来源:互联网 发布:uk国家域名缩写 编辑:程序博客网 时间:2024/05/16 00:28

今天在论坛中有人问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等等.

原创粉丝点击