基于ASP.NET的Web動態(tài)控件建
發(fā)布時間:2008-06-03 閱讀數(shù): 次 來源:網樂原科技
摘要:web設計中,有很多場合,頁面的控件要動態(tài)創(chuàng)建甚至只能動態(tài)創(chuàng)建,這樣可以增加頁面的靈活性,但是給程序員帶來了一些麻煩,比如要使用動態(tài)創(chuàng)建的控件,怎么使用,都是要求解決的問題,本文基于asp.net,簡要介紹了頁面的控件如何動態(tài)創(chuàng)建,同時也介紹了怎么使用這些動態(tài)創(chuàng)建的控件的方法。
前言:
自從Microsoft在2000年推出了.net framework以來,給基于internet編程的程序員帶來了巨大的福音,.net framework大大簡化了web頁面設計的繁雜,可見即可得的頁面效果大大簡化了頁面設計程序員的工作任務,code behind技術將頁面與代碼分離,減少了web頁面的無序狀態(tài),其中大量可以復用的控件可以無縫的被瀏覽器使用,由于互聯(lián)網上95%的瀏覽器均是Microsoft的Internet Explorer,程序員大可以放心的使用這些控件而不用擔心瀏覽器的兼容性,本文從Microsoft的.net和com控件開始,給出具體例子說明如何在頁面上動態(tài)創(chuàng)建控件,以及怎么來使用這些動態(tài)創(chuàng)建的控件。其中具體使用的語言是vb.net。
1. Microsoft控件
目前用于瀏覽器的動態(tài)數(shù)據(jù)瀏覽方式主要有以下兩種,(1).使用java applet。(2).使用可以在瀏覽器中運用的控件。兩種方法各有利弊,使用java applet,頁面執(zhí)行較慢,編程復雜,可復用性不大,這種方式現(xiàn)在使用較少;越來越多的程序員較傾向于使用控件。其中我們在web中大多數(shù)時候是使用到.net 的web control和html control以及一些數(shù)據(jù)操作控件。
一般的,在web設計中,通常使用拖拽的方式,將空間放置到頁面,然后設置屬性就可以了,然后再后臺程序中編程使用就可以了。這種方式操作起來很方便,可見即可得,同時引用這些放置好的控件也很方便,但是在有些情況下,我們卻不得不要動態(tài)創(chuàng)建控件,比如對一一個數(shù)據(jù)庫中的某一些字段,對于不同身份的用戶,見到的字段數(shù)目是不一樣的;還有就是對于不同身份的用戶對于某一控件的使能狀態(tài)是不一樣的,我們不能再頁面設計時采用一個標準,最好的方式就是動態(tài)創(chuàng)建控件,對于不同的情況,通過程序來控制,放置在頁面上的控件的數(shù)目也通過程序來控制。然后通過程序來引用這些創(chuàng)建好的控件。
2. 創(chuàng)建控件
對于程序員來說,用例子說話是最好的方式來提供解決方案,我將在頁面上動態(tài)的放置一些標簽(label)和文本框(textbox),這些文本框里頭放置的是從dataset取到的數(shù)據(jù),同時我把這些文本框放置到一個表格的相應單元格里,可以實現(xiàn)有序的放置,首先在頁面添加一個table。然后根據(jù)需要創(chuàng)建不同的列數(shù)和行數(shù),如下為動態(tài)創(chuàng)建這些文本框的代碼:
Dim i As Integer
For i = 0 To IntRowCount - 1
Dim r As TableRow = New TableRow()
Dim c1 As TableCell = New TableCell()
Dim myLabel1 As Label = New Label()
‘這里設置該label的ID,對于不同的label,必須設置成不同的ID,我這里設置成前綴lbl1加字段名的組合,例如lbl1xlmc等。
myLabel1.ID = "Lbl1" & Trim(OleDsField.Tables("Field").Rows(i).Item("column_name")).ToString()
‘下面的條件語句是為了判斷數(shù)據(jù)庫中在字段的值是否為空,根據(jù)條件賦予label不同的文本。
If OleDsField.Tables("Field").Rows(i).Item("column_title").GetType.ToString = "System.DBNull" Then
myLabel1.Text = ""
Else
myLabel1.Text = Trim(OleDsField.Tables("Field").Rows(i).Item("column_title"))
End If
c1.Controls.Add(myLabel1)
r.Cells.Add(c1)
Dim c2 As TableCell = New TableCell()
Dim mytextbox As TextBox = New TextBox()
mytextbox.ID = "Txt" & Trim(OleDsField.Tables("Field").Rows(i).Item("column_name")).ToString()
If OleDsResult.Tables("Result").Rows(0).Item(i).GetType.ToString = "System.DBNull" Then
mytextbox.Text = ""
Else
mytextbox.Text = Trim(OleDsResult.Tables("Result").Rows(0).Item(i))
End If
If Trim(OleDsField.Tables("Field").Rows(i).Item("column_enable")) = "是" Then
mytextbox.Enabled = True
Else
mytextbox.Enabled = False
End If
c2.Controls.Add(mytextbox)
r.Cells.Add(c2)
Table3.Rows.Add(r)
Next
這樣就成功地添加了兩列到表里,至于行數(shù)由變量IntRowCount決定,其中IntRowCount為取數(shù)據(jù)庫時得到的記錄的行數(shù)
3. 使用動態(tài)創(chuàng)建的控件
使用這些控件時,首先必須要知道這些控件的ID,對于上文所說的這些控件,由于ID名稱不定,使用時必須也要根據(jù)條件來使用。比如我要找到相應的文本框的ID,就用以下代碼可以實現(xiàn):
Dim txt As TextBox
txt = Me.FindControl("txt" & OleDsField.Tables("Field").Rows(i).Item("column_name"))
這樣就找到了要使用的文本框的這個控件,然后就可以使用相應功能。
4. 小結
使用動態(tài)創(chuàng)建控件時,難點在于怎么來操作這些動態(tài)創(chuàng)建的控件。本文給出了代碼,本文例子在.net 2002+windows 2000下調試通過。