讓 SqlDataSource 的 SelectCommand 屬性值不會消失

讓 SqlDataSource 的 SelectCommand 屬性值不會消失

承上一篇「SqlDataSource 執行資料篩選」中,可以知道 SqlDataSource 的 SelectCommand 屬性值不會被保留在 ViewState 中,所以我們在 Page 中覆寫 LoadViewState 及 SaveViewState 方法來維護 SqlDataSource 的 SelectCommand 屬性值。

不過這樣每次動態設定 SelectCommand 屬性值都要這樣處理,感覺上會比較麻煩點;是否能讓 SqlDataSource 控制項的 SelectCommand 屬性值可以由控制項本身自行維護狀態呢?當然可以,而且非常簡單,只要把上篇中覆寫 LoadViewState 及 SaveViewState 方法的作法直接搬到自訂 SqlDataSource 控制項即可。

繼承 SqlDataSource 命名為 TBSqlDataSource,覆寫 LoadViewState 及 SaveViewState 方法來維護 SelectCommand 屬性,這樣就可以更方便使用 SelectCommand 屬性,而無需由每個頁面去自行處理。

Namespace WebControls
    Public Class TBSqlDataSource
        Inherits SqlDataSource

#Region " ViewState 狀態管理 "

        ''' <summary>
        ''' 由 ViewState 還原控制項的狀態。
        ''' </summary>
        ''' <param name="savedState">要還原的控制項狀態。</param>
        Protected Overrides Sub LoadViewState(ByVal savedState As Object)
            If Not (savedState Is Nothing) Then
                ' Load State from the array of objects that was saved at ;
                ' SavedViewState.
                Dim myState As Object() = CType(savedState, Object())

                If Not (myState(0) Is Nothing) Then
                    MyBase.LoadViewState(myState(0))
                End If

                If Not (myState(1) Is Nothing) Then
                    Me.SelectCommand = CType(myState(1), String)
                End If
            End If
        End Sub

        ''' <summary>
        ''' 控制項的狀態儲存至 ViewState。
        ''' </summary>
        ''' <returns>含有控制項之目前檢視狀態的物件。</returns>
        Protected Overrides Function SaveViewState() As Object
            Dim baseState As Object = MyBase.SaveViewState()
            Dim myState(1) As Object
            myState(0) = baseState
            myState(1) = Me.SelectCommand
            Return myState
        End Function

#End Region

    End Class
End Namespace

ASP.NET 魔法學院