GridView的 RowDataBound與 RowCreated事件--[Case Study]GridView按Edit後帶入預設值

摘要:GridView的 RowDataBound與 RowCreated事件--[Case Study]GridView按Edit後帶入預設值





 

 

 

 

之前做過一個類似的範例: GridView的 RowDataBound與 RowCreated事件--[Case Study]成績低於60分就出現紅字

 

這個範例,可以補充在「上集」 Ch. 11

只要學過 RowDataBounde / RowCreated兩個事件之後

 

我準備的七個小範例,只要學會「第六個」範例就能做出本範例

 

 

Q : GridView按Edit後帶入預設值

 

      如果您只會操作 Visual Studio的精靈畫面,我想是作不出這種功能的

      但只要自己寫程式,

      卻非常簡單。

 

 

HTML畫面設計

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

想要好寫一點,建議先轉成「樣版」

 

透過 .FindControl()方法比較好作。透過 .Controls集合來寫,很麻煩而且常錯

例如:連續兩篇文章,請接連看下去 --上集 Ch.10 -- .Controls() / .Controls[]的補充範例 #1

 

            <asp:GridView ID="GridView1" runat="server" AllowPaging="True" AutoGenerateColumns="False" 
                DataKeyNames="id" DataSourceID="SqlDataSource1" OnRowDataBound="GridView1_RowDataBound">
                <Columns>
                    <asp:CommandField ShowEditButton="True" />
                    <asp:BoundField DataField="id" HeaderText="id" InsertVisible="False" ReadOnly="True" SortExpression="id" />
                    <asp:BoundField DataField="test_time" HeaderText="test_time" SortExpression="test_time" />
                    <asp:TemplateField HeaderText="title" SortExpression="title">
                        <EditItemTemplate>
                            <asp:TextBox ID="TextBox1" runat="server" Text='<%# Bind("title") %>'></asp:TextBox>
                        </EditItemTemplate>
 
                        <ItemTemplate>
                            <asp:Label ID="Label1" runat="server" Text='<%# Bind("title") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
                </Columns>
            </asp:GridView>
 
 
            <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
                ConnectionString="<%$ ConnectionStrings:testConnectionString %>" 
                SelectCommand="SELECT [id], [test_time], [title] FROM [test]" 
                UpdateCommand="UPDATE [test] SET [test_time] = @test_time, [title] = @title WHERE [id] = @id">
 
                <UpdateParameters>
                    <asp:Parameter Name="test_time" Type="DateTime" />
                    <asp:Parameter Name="title" Type="String" />
                    <asp:Parameter Name="id" Type="Int32" />
                </UpdateParameters>
            </asp:SqlDataSource>

 

 

後置程式碼

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

程式的重點在於 e.Row.RowState

 

您會發現 e.Row.RowState 抓到的 Edit,只是「單數列」的編輯模式

一旦點選「雙數列(偶數列)」的編輯模式,就會抓不到

 

修正後如下:

 

    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
 
            if (e.Row.RowState == DataControlRowState.Edit || 
                      e.Row.RowState == (DataControlRowState.Edit | DataControlRowState.Alternate))
            {
                    TextBox tb = (TextBox)e.Row.FindControl("TextBox1");
 
                    tb.Text = "進入編輯模式,立刻給予「預設值」。";
 
            }
        }
    }

 

因為程式碼很簡單,所以不提供VB語法了。

 

 

 

 

要把一個觀念學好、要把一個方法、屬性學會

需要很多小範例,讓您不斷練習,才會瞭解其中的奧妙

 

微軟MSDN的範例就是如此,小而美

針對重點來實作

 

但很可惜,MSDN網站通常只給一個範例,有時候也會遇見「只解說、沒範例」的情況

 

我的範例與課程補強這一點,

針對同一個重點,我一而再、再而三提供範例來「實作」

做到會為止!

 

 

 

 

 

 

 

 

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

猶如一人以我的燭火點燭,光亮與他同在,我卻不因此身處黑暗。----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小時)完整內容,"免費"讓您評估