[習題]動態新增 DropDownList或 ListBox底下的新項目(Item)#3 -- AppendDataBoundItems屬性

先靜態加入一個子選項,
後續再從資料庫裡面撈資料,補充到 DropDownList裡面當成新的子選項。





相關的習題,可以參考以前的文章:

1)  http://www.dotblogs.com.tw/mis2000lab/archive/2008/10/09/dropdownlist_items.add081009.aspx

2)  http://www.dotblogs.com.tw/mis2000lab/archive/2008/12/01/listbox.item_add_remove.aspx

 

 

也可以參考  ASP.NET專題實務(文魁出版)的上冊,裡面的第三章 DropDownList。

===================================

有讀者詢問:
      他想先靜態加入一個子選項,
      後續再從資料庫裡面撈資料,補充到 DropDownList裡面當成新的子選項。

      但發現一個問題 --  每一次從資料庫撈出資料後,動態加入的子選項,

                                      會覆蓋一開始 "靜態設定"的(自己動手寫的)子選項

 

執行畫面與步驟如下 :

------------------------------------------------------------------------------

 

 

 

 

如果我沒有會錯意的話,這題目並不難
(也可能我會錯意了)。


1.  首先,我們先幫 DropDownList動手加入一個靜態的子選項,例如:「歡迎挑選」這四個字

01 <body>
02     <form id="form1" runat="server">
03     <p>
04         <br />
05         <asp:Button ID="Button1" runat="server" Text="按下這個按鈕, 就會看見成果" />
06     </p>
07     <div>
08      
09         <asp:DropDownList ID="DropDownList1" runat="server">
10             <asp:ListItem>~~~歡迎選擇~~~(自己動手寫入的、靜態加入)</asp:ListItem>
11         </asp:DropDownList>
12      
13     </div>
14     </form>
15 </body>

 


2.  然後從資料庫裡面撈資料,以某一個欄位來當作(動態加入) DropDownList新的子選項

重點在於底下的 While dr.Read() ... End While迴圈

01 '----自己寫的----
02 '----自己寫的----
03 Imports System
04 Imports System.Web.Configuration
05 Imports System.Data
06 Imports System.Data.SqlClient

07 '----自己寫的----
08
09
10
11
12     Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button1.Click
13         '=======微軟SDK文件的範本=======
14         Dim Conn As New SqlConnection(WebConfigurationManager.ConnectionStrings("testConnectionString").ConnectionString.ToString())
15
16         Dim dr As SqlDataReader = Nothing
17
18         Dim cmd As New SqlCommand("select id,title from test", Conn)
19
20         Try     '==== 以下程式,只放「執行期間」的指令!=====================
21             Conn.Open()   '---- 這時候才連結DB
22
23             dr = cmd.ExecuteReader()   '---- 這時候執行SQL指令,取出資料
24
25             While dr.Read()
26                 DropDownList1.Items.Add(dr.Item("title"))
27             End While
28
29         Catch ex As Exception   '---- 如果程式有錯誤或是例外狀況,將執行這一段
30             Response.Write("<b>Error Message----  </b>" + ex.ToString() + "<HR/>")
31
32         Finally
33             '---- Always call Close when done reading.
34             If Not (dr Is Nothing) Then
35                 cmd.Cancel()
36                 dr.Close()
37             End If
38
39             '---- Close the connection when done with it.
40             If (Conn.State = ConnectionState.Open) Then
41                 Conn.Close()
42                 Conn.Dispose()
43             End If
44
45         End Try
46     End Sub

 

 

 相關習題,請參考 [習題] DropDownList / ListBox連動,查詢菜單

 

 

 

 

 

 

 

今日值班正妹 , 李毓芬

資料來源 --  http://images.google.com/images?hl=zh-tw&q=%E6%9D%8E%E6%AF%93%E8%8A%AC&rlz=1I7GGLL_zh-TW&um=1&ie=UTF-8&sa=N&tab=wi

 

     

 

 

 

我將思想傳授他人, 他人之所得,亦無損於我之所有;

猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----Thomas Jefferson

線上課程,遠距教學 (Web Form 49hr)  https://dotblogs.com.tw/mis2000lab/2016/02/01/aspnet_online_learning_distance_education_VS2015

線上課程,遠距教學 (ASP.NET MVC 75hr)  https://dotblogs.com.tw/mis2000lab/2018/08/14/ASPnet_MVC_Online_Learning_MIS2000Lab

ASP.NET MVC線上課程 第一天 免費看 (5.5小時) 

寫信給我,不要私訊 --  mis2000lab (at) yahoo.com.台灣  或  school (at) mis2000lab.net


ASP.NET遠距教學、線上課程(Web Form + MVC)。 第一天課程, "完整" 試聽。 

................   facebook社團   https://www.facebook.com/mis2000lab   ......................

................  YouTube (ASP.NET) 線上教學影片  https://www.youtube.com/channel/UC6IPPf6tvsNG8zX3u1LddvA/

 

Blog文章 "附的範例" 無法下載,請看 這裡 ...... https://dotblogs.com.tw/mis2000lab/2016/03/14/2008_2015_mis2000lab_sample_download

請看我們的「售後服務」範圍(嚴格認定)

......................................................................................................................................................

...................................................................................................................................................... 

[遠距教學、教學影片] ASP.NET (Web Form) 課程 上線了!MIS2000Lab.主講

事先錄製好的影片,並非上課時側錄!   觀看影片時,有如我「一對一」跟您面對面講課

 

ASP.NET MVC 5 線上教學

累積時數約 75小時...... 第一天(5.5小時)完整內容,"免費"讓您評估