让 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 Namespace WebControls
    
Public Class TBSqlDataSourceClass TBSqlDataSource
        
Inherits SqlDataSource

ViewState 状态管理#Region " ViewState 状态管理 "

        
/**/''' <summary>
        
''' 由 ViewState 还原控件的状态。
        
''' </summary>
        
''' <param name="savedState">要还原的控件状态。</param>

        Protected Overrides Sub LoadViewState()Sub LoadViewState(ByVal savedState As Object)
            
If Not (savedState Is NothingThen
                
' Load State from the array of objects that was saved at ;
                ' SavedViewState.
                Dim myState As Object() = CType(savedState, Object())

                
If Not (myState(0Is NothingThen
                    
MyBase.LoadViewState(myState(0))
                
End If

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


        
/**/''' <summary>
        
''' 控件的状态储存至 ViewState。
        
''' </summary>
        
''' <returns>含有控件之目前检视状态的对象。</returns>

        Protected Overrides Function SaveViewState()Function SaveViewState() As Object
            
Dim baseState As Object = MyBase.SaveViewState()
            
Dim myState(1As Object
            myState(
0= baseState
            myState(
1= Me.SelectCommand
            
Return myState
        
End Function


#End Region


    
End Class

End Namespace
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值