我們先來看一個(gè)簡(jiǎn)單的例子:
- <% @ Page Language="C#" %>
- <% @ Import Namespace="System.Data" %>
- <Script Language="C#" Runat="Server">
- public void Page_Load(Object src,EventArgs e)
- {
- //首先建立一個(gè)數(shù)組
- ArrayList arr=new ArrayList();
- arr.Add("飛刀");
- arr.Add("Zsir");
- arr.Add("大風(fēng)");
- arr.Add("布丁");
- arr.Add("亞豪");
-
- //將數(shù)組捆綁到DropDownList控件上去
- DDL.DataSource = arr;
- DDL.DataBind();
- }
- </script>
- <html>
- <head>
- <title></title>
- </head>
- <body>
- <asp:DropDownList id="DDL" runat="server" />
- </body>
- </html>
我們?cè)诖a中可以看到我們建立了一個(gè)DropDownList,但是他沒有<asp:ListItem>屬性,而我們從最后的顯示中依然可以看到我們所列出的選項(xiàng)。
這里就是我們用DataBind的結(jié)果,在Page_Load方法中我們建立了一個(gè)數(shù)組(ArrayList),并通過DataBind方法將這個(gè)數(shù)組捆綁到了DropDownList控件中,使得DropDownList最后有數(shù)據(jù)顯示:),怎么樣對(duì)Bind有一定感性認(rèn)識(shí)了吧。下面我們開始正式講解
其實(shí)DataBind(),不僅能對(duì)控件進(jìn)行捆綁,而且還能夠?qū)?yè)面中屬性,方法進(jìn)行捆綁,甚至整個(gè)頁(yè)面都可以捆綁。比如,調(diào)用Page.DataBind()方法或者直接使用DataBind(),那么整個(gè)頁(yè)面都將被捆綁,所有的數(shù)據(jù)全在監(jiān)視之下。下面的例子,我們將使用DataBind方法來捆綁DropDownList,并獲得其中的數(shù)據(jù)
- <% @ Page Language="C#" %>
- <% @ Import Namespace="System.Data" %>
- <Script Language="C#" Runat="Server">
- public void sub_Click(Object sender,EventArgs e)
- {
- Page.DataBind();
- }
- </script>
- <html>
- <head>
- <title></title>
- </head>
- <body>
- <form runat=server>
- <asp:DropDownList id="DDL" runat="server" >
- <asp:ListItem>ASP技術(shù)</asp:ListItem>
- <asp:ListItem selected>ASP.Net技術(shù)</asp:ListItem>
- <asp:ListItem>JSP技術(shù)</asp:ListItem>
- <asp:ListItem>PHP技術(shù)</asp:ListItem>
- <asp:ListItem>組件技術(shù)</asp:ListItem>
- </asp:DropDownList>
- <br>
- 你現(xiàn)在選擇的是:<font color=red><%# DDL.SelectedItem.Text %></font>區(qū)
- <br>
- <asp:Button id="sub" Text="提交" Type="submit" runat=server OnClick="sub_Click" />
- </form>
- </body>
- </html>
我們看到,那個(gè)紅色的[JSP技術(shù)],我們并沒有使用什么控件,但是他卻能正確的顯示我們的選擇結(jié)果,這個(gè)是就捆綁的結(jié)果,注意<%# DDL.SelectedItem.Text %>這句話,正是它讓我們?nèi)〉昧死壍臄?shù)據(jù)。它看上去是不是像我們熟悉的<%=...%>這個(gè)語(yǔ)句,它們的使用方法相差不多,只是<%=...%>是在程序執(zhí)行時(shí)調(diào)用,<%#... %>是在DataBind()方法之后被調(diào)用。以后我們還能經(jīng)常看到他的身影,呵呵。
接收Bind的控件,一般有DropDownList,DataList,DataGrid,ListBox這些集合性質(zhì)的控件,而被捆綁的主要是ArrayList(數(shù)組),Hashtable(哈稀表),DataView(數(shù)據(jù)視圖),DataReader這四個(gè),以后我們就可以對(duì)號(hào)入座,不會(huì)出現(xiàn)DataTable被捆綁的錯(cuò)誤了:)
講到Bind,就不能說一下DataBinder.Eval()方法.
我們?cè)谑褂肈ataBind,獲得的數(shù)據(jù),系統(tǒng)會(huì)將其默認(rèn)為String(字符串),這對(duì)我們平時(shí)的輸出顯示提供了極大的方便,但是我們并不是每次都需要string類型,有時(shí)我們就需要Boolean,Int32這些類型。此時(shí)我們就需要轉(zhuǎn)化類型了。可能大家最先想到的是String.Format方法,這是最好的,但是用法過于煩。所以最好不要這樣啦。我們可以用DataBinder.Eval()方法,他的格式是:
DataBinder.Eval(Container.DataItem,"轉(zhuǎn)換的類型","格式")
最后一個(gè)"格式"是可選的,一般不用去管他,Container.DataItem是捆綁的數(shù)據(jù)項(xiàng),"轉(zhuǎn)換類型"指的是Integer,String,Boolean這一類東西.
有了它,我們處理數(shù)據(jù)就更加方便
最后我們來看一個(gè)例子,關(guān)于DataView的捆綁,呵呵,老是用DropDownList煩了,這次用DataGrid,在這個(gè)例子中我們可以看到"表是怎樣煉成的"
- <% @ Page Language="C#" %>
- <% @ Import Namespace="System.Data" %>
- <Script Language="C#" Runat="Server">
- public void Page_Load(Object src,EventArgs e)
- {
- int i;
- //建立表數(shù)據(jù)
- DataTable dt=new DataTable();
- DataRow dr;
- //建立Column例,可以指明例的類型,這里用的是默認(rèn)的string
- dt.Columns.Add(new DataColumn("編號(hào)"));
- dt.Columns.Add(new DataColumn("用戶名"));
- for(i=1;i<8;i++)
- {
- dr=dt.NewRow();
- dr[0]=Int32.ToString(i);
- dr[1]="aspcn"+Int32.ToString(i);
- dt.Rows.Add(dr);
- }
- //捆綁
- DG1.DataSource = new DataView(dt);
- DG1.DataBind();
-
-
- }
- </script>
- <html>
- <head>
- <title></title>
- </head>
- <body>
- <asp:DataGrid id="DG1" runat=server align=center HeaderStyle-BackColor="#aaaadd" />
-
- </body>
- </html>