国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

【Ext.Net學習筆記】04:Ext.Net中使用數據、Ext.Net Store的用法、Ext.Net ComboBox用法

2019-11-17 01:33:52
字體:
來源:轉載
供稿:網友

【Ext.Net學習筆記】04:Ext.Net中使用數據、Ext.Net Store的用法、Ext.Net ComboBox用法

之前的幾篇文章都是介紹Ext.Net較為基礎的東西,今天的這一篇將介紹數據的一些用法,包括XTemplate綁定數據、Store(Modal、PRoxy)、ComboBox的用法等。

XTemplate綁定數據

XTemplate是個模板,當我們為一個XTemplate綁定數據之后,將會按照模板的預定格式進行顯示。

<ext:Window runat="server" ID="win1"    Title="XTemplates用法" Width="300" Height="200">    <Tpl runat="server">        <Html>            <div class="info">                <p>姓名:{Name}</p>                <p>性別:{Gender}</p>                <p>年齡:{Age}</p>            </div>        </Html>    </Tpl></ext:Window>

然后我們有一個這樣的實體類:

public class UserInfo{    public string Name { get; set; }    public string Gender { get; set; }    public int Age { get; set; }}

UserInfo類中的字段分別對應模板中字段對應。然后我們在頁面加載的時候完成數據綁定:

protected void Page_Load(object sender, EventArgs e){    UserInfo userInfo = new UserInfo()    {        Name = "呂布",        Gender = "男",        Age = 24    };    win1.Data = userInfo;}

來看看顯示效果:

使用Store處理數據

Store可以理解為一個數據容器,它包含Modal和Proxy。

  • Modal:數據模型,包括一些字段等,通常與數據庫中的字段、實體模型中的字段對應。
  • Proxy:數據交互的代理,包括MemoryProxy、AjaxProxy、DirectProxy等

接下來是一個例子,這個例子中使用了DataView來顯示數據,使用Store來提供數據,這個例子仍然使用我們上面的UserInfo類。

<ext:Panel runat="server" Width="600" Height="400" AutoScroll="true">    <Items>        <ext:DataView runat="server" ID="myDataView" ItemSelector=".info">            <Store>                <ext:Store runat="server" ID="storeUserInfo" PageSize="6">                    <Model>                        <ext:Model runat="server" IDProperty="Name">                            <Fields>                                <ext:ModelField Name="Name" Type="String"></ext:ModelField>                                <ext:ModelField Name="Gender" Type="String"></ext:ModelField>                                <ext:ModelField Name="Age" Type="Int"></ext:ModelField>                            </Fields>                        </ext:Model>                    </Model>                </ext:Store>            </Store>            <Tpl runat="server">                <Html>                    <tpl for=".">                        <div class="info">                            <p>姓名:{Name}</p>                            <p>性別:{Gender}</p>                            <p>年齡:{Age}</p>                        </div>                    </tpl>                </Html>            </Tpl>                    </ext:DataView>    </Items>    <BottomBar>        <ext:PagingToolbar runat="server" StoreID="storeUserInfo"></ext:PagingToolbar>    </BottomBar></ext:Panel>

在這段代碼中,我們定義了一個DataView,DataView中包含了一個Store和一個Tpl模板,在代碼的最后,我們添加了分頁處理,使用了PagingToolbar。我們在后臺代碼中為Store綁定數據:

        protected void Page_Load(object sender, EventArgs e)        {            BindDataView();        }        protected void BindDataView()        {            List<UserInfo> userInfoList = new List<UserInfo>();            for (int i = 1; i <= 11; i++)            {                UserInfo userInfo = new UserInfo()                {                    Name = "David" + i,                    Gender = "男",                    Age = 18 + i                };                userInfoList.Add(userInfo);            }            storeUserInfo.DataSource = userInfoList;            storeUserInfo.DataBind();        }

CSS樣式:

.info { border: 1px solid #ccc; padding:5px; margin:5px; width:280px; float:left; background:#efefef; }

效果如下:

Ext.Net Store的用法

介紹了如何使用數據,將數據綁定在一個DataView中進行顯示,里面用到了Store,只不過那是一個直接綁定所有數據的Store,并不具備遠程獲取數據、遠程排序、分頁等功能,今天我們來看看如何實現。

使用Handler處理分頁

首先來創建一般處理程序,我命名為StoreHandler.ashx,然后它的處理過程代碼如下:

public void ProcessRequest(HttpContext context){    context.Response.ContentType = "application/json";    var requestParams = new StoreRequestParameters(context);    int start = requestParams.Start;    int limit = requestParams.Limit;    DataSorter[] sorter = requestParams.Sort;    DataFilter[] filter = requestParams.Filter;    Paging<UserInfo> employees = GetPageData(start, limit, filter, sorter);    context.Response.Write(JSON.Serialize(employees));}

這個方法中,我們首先使用HttpContext創建一個StoreRequestParameters對象,這個對象中包含Start、Limit、Page、Sort、Filter、Group等參數。

  • Start:從第幾行開始獲取數據記錄
  • Limit:獲取數據的量,一次獲取多少行數據
  • Page:當前的頁碼
  • Sort:排序的條件集合
  • Filter:過濾的條件集合
  • Group:分組的條件集合

我們在獲取到這些數據以后,通過GetPageData來取到符合條件的數據,然后創建一個Paging<T>類的實例,這個類中包含了Data和TotalRecords兩個重要的屬性

  • Data:IEnumerable<T>類型的數據集合
  • TotalRecords:數據總行數,用于客戶端分頁(生成頁碼)

我們的獲取數據方法的代碼如下:

public Paging<UserInfo> GetPageData(int start, int limit,    DataFilter[] filter, DataSorter[] sorter){    var userInfoList = UserInfo.GetData();    Paging<UserInfo> result = new Paging<UserInfo>();    result.TotalRecords = userInfoList.Count;    result.Data = userInfoList.Skip(start).Take(limit).ToList();    return result;}

Index.aspx.cs文件部分代碼:

    public partial class Index : System.Web.UI.Page    {        protected void Page_Load(object sender, EventArgs e) { }            }    public class UserInfo    {        public string Name { get; set; }        public string Gender { get; set; }        public int Age { get; set; }        public static  List<UserInfo> GetData()        {            List<UserInfo> userInfoList = new List<UserInfo>();            for (int i = 1; i <= 11; i++)            {                UserInfo userInfo = new UserInfo()                {                    Name = "David" + i,                    Gender = "男",                    Age = 18 + i                };                userInfoList.Add(userInfo);            }            return userInfoList;        }    }

有了這個handler,我們接下來需要對Store進行改造:

<ext:Store runat="server" ID="storeUserInfo" PageSize="6" RemoteFilter="true" RemoteSort="true">    <Model>        <ext:Model ID="Model1" runat="server" IDProperty="Name">            <Fields>                <ext:ModelField Name="Name" Type="String"></ext:ModelField>                <ext:ModelField Name="Gender" Type="String"></ext:ModelField>                <ext:ModelField Name="Age" Type="Int"></ext:ModelField>            </Fields>        </ext:Model>    </Model>    <Proxy>        <ext:AjaxProxy Url="StoreHandler.ashx">            <ActionMethods Read="GET" />            <Reader>                <ext:JsonReader Root="data" />            </Reader>        </ext:AjaxProxy>    </Proxy></ext:Store>

AjaxProxy的Url就是我們的Handler地址。ActionMethods是請求方式,JsonReader是reader屬性,它獲取的數據根節點是data。這里都是根據ExtJS中ajaxproxy來定義的,你可以通過看原文博主之前的文章來了解這方面的內容:ExtJS 4.2 教程-06:服務器代理(proxy),顯示效果和前面的一樣。

PageProxy分頁的實現

PageProxy是Ext.Net實現的一種分頁方式,它與使用handler的方式不同,PageProxy通過實現OnReadData事件來完成分頁。

這里我們直接看Store的代碼:

<ext:Store runat="server" ID="storeUserInfo" PageSize="6" OnReadData="storeUserInfo_ReadData">    <Model>        <ext:Model ID="Model1" runat="server" IDProperty="Name" >            <Fields>                <ext:ModelField Name="Name" Type="String"></ext:ModelField>                <ext:ModelField Name="Gender" Type="String"></ext:ModelField>                <ext:ModelField Name="Age" Type="Int"></ext:ModelField>            </Fields>        </ext:Model>    </Model>    <Proxy>        <ext:PageProxy></ext:PageProxy>    </Proxy></ext:Store>

然后再后臺代碼中實現storeUserIn

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 玉山县| 金昌市| 宁国市| 大港区| 盐边县| 苍梧县| 驻马店市| 澜沧| 察隅县| 宣威市| 福州市| 山阳县| 克东县| 滨海县| 长乐市| 五台县| 黎城县| 葫芦岛市| 奉贤区| 平罗县| 荔浦县| 江阴市| 清河县| 紫金县| 塔城市| 寿宁县| 秦皇岛市| 大理市| 景德镇市| 六安市| 邵阳市| 阿坝县| 拉萨市| 龙陵县| 六枝特区| 惠水县| 武强县| 东乌珠穆沁旗| 汨罗市| 梅州市| 温宿县|