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

首頁 > 編程 > .NET > 正文

ASP.NET中Datagrid常見錯誤_.Net教程

2024-07-10 12:50:29
字體:
來源:轉載
供稿:網友

推薦:在網頁中動態的生成一個圖片
大家知道股票網站的K線圖是動態生成的定時刷新PHP 就有動態生成圖片的功能.那么怎樣用asp.net在網頁中動態的生成一個圖片呢?下面我要舉的例子是動態的生成一個圖片顯示當前時間.

摘要:學習如何避免在使用 ASP.NET Datagrid 控件進行開發時可能發生的一些常見錯誤。

Datagrid 控件是 Microsoft? ASP.NET 中功能最強、用途最廣的 Web 控件之一,這一點已經得到了 ASP.NET 權威人士的認同。雖然 Datagrid 控件易于使用,但同樣易于給使用者帶來麻煩。以下是許多人所犯的一些錯誤,這些人包括從初學者到富有經驗的 .NET 專家。您可以看到許多苦悶的使用者在 ASP.NET 新聞組和論壇就這些錯誤提出問題。遵循本文概述的相當簡單的步驟,可以幫助您避免這些錯誤,并節約大量的開發時間。

可以使用 Datagrid 創建列表數據而沒有使用

我知道您不會再使用如下所示的代碼,但 ASP.NET 領域中許多守舊的用戶仍在繼續使用它們:

Response.Write("<table>")
While MyDataReader.Read()
Response.Write("<tr>")
Response.Write("<td>")
Response.Write(MyDataReader(0))
Response.Write("</td>")
Response.Write("</tr>")
Loop
Response.Write("</table>")

可以對以上代碼進行簡化,使其僅為:

<asp:datagrid runat="server" datasource="MyDataReader"/>

并調用 .DataBind() 方法。即使需要對HTML輸出進行特殊的控制,您也可以在用戶界面上記錄集的內容重復出現的情況下,使用某個數據 Web 控件。

忘記在 Page_Load 事件中檢查 IsPostBack

最常見的錯誤之一是忘記在數據綁定之前檢查頁面的 IsPostBack 條件。例如,Datagrid 處于“Edit”(編輯)模式時,忽略該項檢查將導致已編輯的值被數據源中的原始值覆蓋。然而,該規則至少有一個主要的例外,請參閱持續使用大型 ViewState。

以下是包含 IsPostBack 檢查的一個典型 Page_Load 事件。BindGrid() 是一個例程,用于導入并設置 Datagrid 的數據源,并調用 DataBind() 方法。

Sub Page_Load
If Not IsPostBack Then
BindGrid()
End If
End Sub

需要更大的靈活性時,仍堅持使用自動生成的列

如果 Datagrid 所處的環境需要任何一種特殊格式,或是需要使用 Datagrid 中的其他任何 Web 控件,那么必須關閉 AutoGenerateColumns。將 AutoGenerateColumns 屬性的設置保持為“True”(默認設置)的做法,僅在最簡單的 Datagrid 方案中有效。但對幾乎所有實際的應用程序,必須將該屬性設置為“False”,并在 Datagrid 聲明的 <columns></columns> 段中明確地指定列。Microsoft Visual Studio? .NET 用戶可以使用屬性生成器以圖形化的方式創建這些列。

注意:如果將 AutoGenerateColumns 的設置保持為“True”,并且在 Datagrid 的 <columns> 段中指定了列,那么最終將得到對列的重復設置。系統將首先顯示特別聲明的列,隨后是所有自動生成的列。

嘗試僅使用控件 ID 來引用 Datagrid 項目中的控件

許多人沒有認識到,對于 Datagrid 的 TemplateColumn 下的 ItemTemplate 中的控件(例如帶有“MyTextBox”ID 的 TextBox 控件),不能在后面的代碼或是在 ASPX 頁面的 <script> 段中用如下所示的代碼來直接調用該控件:

Dim MyValue As String = MyTextBox.Text

該代碼將導致可怕的“名稱‘MyTextBox’沒有聲明”錯誤。

因為 Datagrid 是由多個行(項目)組成的,所以數據源中的每一行實際都會有一個單獨的“MyTextBox”實例。ASP.NET 在每個控件的 ID 前面加上該控件層次結構中每個命名容器的 ID,這樣 Textbox 將具有唯一的 ID,與頁面中所有其他控件的 ID 都不相同。例如,如果 MyTextBox 處于 DataGrid1 中,那么生成的 ID 將是 DataGrid1:_ctl2:MyTextBox。“_ctl2”代表 MyTextBox 所處的當前行。頁面中其他 MyTextBox 實例的 ID 可能是 DataGrid1:_ctl3:MyTextBox、DataGrid1:_ctl4:MyTextBox 等等。要檢索需要查找的“MyTextBox”值,需要對適當的 DataGridItem 調用 FindControl 方法。該 DataGridItem 用作 TextBox 的父命名容器。

  HTML:

<asp:Datagrid runat="server" id="Datagrid1">
<Columns>
<asp:TemplateColumn>
<ItemTemplate>
<asp:TextBox runat="server" id="MyTextBox"/>
</ItemTemplate>
</asp:TemplateColumn>
</Columns>

  代碼:

Sub DataGrid1_UpdateCommand(sender As Object, e As DataGridCommandEventArgs)
 Dim MyValue As String = CType(e.Item.FindControl("MyTextBox"), TextBox).Text
 '對 MyValue 執行操作
End Sub

對 FindControl 調用的結果調用 CType,將會把返回值由 Object 類型強制轉換成 TextBox 類型,以訪問 .Text 屬性。

忘記在每個 Datagrid 事件中執行 .DataBind() 調用,從而導致回發

一個常見的問題是:“當我點擊 Datagrid 某一行中的 Edit(編輯)鏈接時,頁面回發,且不包含任何數據。這是什么錯誤?”問題在于數據僅在頁面第一次被調用時綁定到網格。在每個 Datagrid 事件(Edit、Update、Cancel、Page 或 Sort)中,請確保設置了 Datagrid 的 Datasource 屬性(除非已經在 <asp:Datagrid> 聲明中通過聲明的方式進行了設置),并對 Datagrid 調用了 DataBind() 方法。

分享:C#是一種新的語言?或者僅僅只是Java
最開始時微軟公司將Java當做一種能解決C和C 中存在的問題的語言,并不在意,并繼續維持和培訓著其C和C 技術和編程人員。接下來不幸的是,正當微軟盡力在Visual J 基礎上拓展Java功能,并使之

共2頁上一頁12下一頁
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 蒙山县| 宣化县| 红原县| 手机| 无锡市| 翁源县| 巴彦淖尔市| 芮城县| 汉寿县| 布拖县| 西藏| 永年县| 和平区| 高碑店市| 新安县| 正阳县| 怀集县| 永平县| 延川县| 始兴县| 竹北市| 达州市| 新乡市| 昌江| 含山县| 葵青区| 右玉县| 抚州市| 乃东县| 道真| 斗六市| 调兵山市| 治县。| 江陵县| 阜新市| 治多县| 霍州市| 磐石市| 枞阳县| 丹寨县| 正宁县|