亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

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

【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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区三区久久| 欧美日韩国产丝袜另类| 欧美性猛交xxxx富婆弯腰| 久久99国产综合精品女同| 欧美另类极品videosbest最新版本| 久久久亚洲欧洲日产国码aⅴ| 欧美另类交人妖| 欧美亚洲国产日本| 国产自摸综合网| 久久国内精品一国内精品| 久久夜色精品国产亚洲aⅴ| 色综合久久88| 亚洲japanese制服美女| 欧美一级电影在线| 亚洲成人久久一区| 日韩精品在线免费播放| 色婷婷av一区二区三区在线观看| 欧美插天视频在线播放| 精品国模在线视频| 浅井舞香一区二区| 国外成人免费在线播放| 国产在线播放91| 日韩大陆毛片av| 国产69精品久久久久9999| 亚洲人线精品午夜| 国产精品入口日韩视频大尺度| 日韩一二三在线视频播| 日韩中文在线中文网在线观看| 欧美日本在线视频中文字字幕| 久久亚洲国产精品成人av秋霞| 久久人人97超碰精品888| 国内精品美女av在线播放| 另类少妇人与禽zozz0性伦| 性色av香蕉一区二区| 亚洲精品国产精品国自产观看浪潮| 久久综合88中文色鬼| 91香蕉嫩草影院入口| 中文字幕久久亚洲| 91亚洲精品在线观看| 欧美精品在线观看| 国产欧美日韩中文字幕在线| 欧美尺度大的性做爰视频| 欧美激情视频一区二区三区不卡| 黄色91在线观看| 久久这里只有精品99| 国产国产精品人在线视| 韩国19禁主播vip福利视频| 国产精品久久久久免费a∨| 国内精品久久久久影院优| 国产成+人+综合+亚洲欧美丁香花| 亚洲欧洲午夜一线一品| 三级精品视频久久久久| 91精品久久久久久久久中文字幕| 久久精品99无色码中文字幕| 欧美韩日一区二区| 911国产网站尤物在线观看| 国产精品无码专区在线观看| 热久久这里只有| 91亚洲一区精品| 国产在线精品一区免费香蕉| 深夜福利91大全| 日韩精品在线观| 亚洲国产精品久久久久秋霞不卡| 久久琪琪电影院| 国产福利精品在线| 美女久久久久久久久久久| 成人中心免费视频| 国产精品免费一区豆花| 国产自产女人91一区在线观看| 亚洲男人天堂2024| 久热精品视频在线免费观看| 国产精品一香蕉国产线看观看| 岛国av一区二区在线在线观看| 亚洲精品久久在线| 欧美亚洲一级片| 欧美巨大黑人极品精男| 最近2019中文免费高清视频观看www99| 久久精品国产欧美激情| 亚洲欧美精品suv| 欧美自拍大量在线观看| 欧美高清第一页| 国产精品v片在线观看不卡| 国产偷国产偷亚洲清高网站| 国产成人久久精品| 欧美成aaa人片免费看| 欧美高清在线播放| 亚洲欧美另类中文字幕| 欧美日韩综合视频网址| 欧美亚洲国产日韩2020| 欧美精品在线观看91| 亚洲男人第一av网站| 欧美劲爆第一页| 精品久久久久久久久中文字幕| 亚洲成人黄色在线| 日韩视频免费看| 国产精品综合不卡av| 中文字幕日韩高清| 成人黄色在线观看| 97精品国产97久久久久久免费| 亚洲爱爱爱爱爱| 国产精品美女久久久久av超清| 亚洲老板91色精品久久| 91wwwcom在线观看| 国产精品高潮视频| 久久精品国产视频| 九九热视频这里只有精品| 欧美天天综合色影久久精品| 亚洲a在线观看| 欧美日韩国产成人| 日韩精品在线观看一区二区| 国产91免费看片| 国产成人久久久精品一区| 亚洲美女视频网| 日韩在线观看高清| 国产精品久久久久久久一区探花| 中文字幕亚洲专区| 欧美成人免费小视频| 国产网站欧美日韩免费精品在线观看| 精品久久久久久久久中文字幕| 国产精品一区二区久久精品| 欧美影院成年免费版| 久久久精品中文字幕| 国产日韩精品在线播放| 久久久久久999| 国产精品日韩精品| 亚洲精选一区二区| 黑人巨大精品欧美一区二区一视频| 98精品国产自产在线观看| 精品调教chinesegay| 亚洲欧美综合精品久久成人| 91福利视频网| 亚洲色图欧美制服丝袜另类第一页| 国产欧美在线看| 国产日韩在线亚洲字幕中文| 欧美乱人伦中文字幕在线| 国产精品入口尤物| 97视频免费观看| 国产www精品| 日韩中文字幕免费视频| 亚洲女人被黑人巨大进入al| 色婷婷**av毛片一区| 亚洲午夜性刺激影院| 日韩精品日韩在线观看| 国产美女被下药99| 91精品久久久久久久久青青| 中文字幕亚洲无线码在线一区| 国产一区二区三区在线视频| 欧美成aaa人片在线观看蜜臀| 欧美孕妇毛茸茸xxxx| 亚洲精品99久久久久中文字幕| 日韩欧美有码在线| 中文字幕精品一区久久久久| 国产精品av在线播放| 久久黄色av网站| 精品视频在线播放色网色视频| 亚洲色图国产精品| 日韩亚洲精品视频| 国产精品激情av在线播放| 亚洲视频在线观看视频| 国内精品一区二区三区| 日韩av手机在线看| 亚洲影院色无极综合| 国产亚洲精品激情久久| 久久九九全国免费精品观看|