主要说一下,有关于如何使用linq查询,筛选,过滤ViewState中需要数据信息, 而不是用linq查询ViewState
以前我们获取ViewState方式一般都是以如下的方式:
Before:
//
获取 ViewState Info
Object obj = ViewState [ " Info " ];
// 检查 ViewState 是否包括相关信息
Object obj = ViewState [ " Info " ];
if ( null != ViewState [ " Info " ] ) {
// TODO
}
Object obj = ViewState [ " Info " ];
// 检查 ViewState 是否包括相关信息
Object obj = ViewState [ " Info " ];
if ( null != ViewState [ " Info " ] ) {
// TODO
}
LinQ:
首先 要对ViewState.Keys进行OfType(),或者Cast()的操作,因为ICollection类型,LinQ是不支持。
然后 如下
代码
var query
=
from vs
in
ViewState.Keys.OfType
<
String
>
()
where vs.Contains ( " info " )
select ViewState [vs];
if ( null != query.Single()){
var info = query.Single();
}
where vs.Contains ( " info " )
select ViewState [vs];
if ( null != query.Single()){
var info = query.Single();
}
最后,蛮简单明了吧。
另外的话 有一种情况,大家要注意一下。
代码
//
Set Info To ViewState
ViewState.Add( " Info " , " Test " );
ViewState.Add ( "dd" , 11 );
// Get Info From ViewState
这里用以上方式就不行了。
var query = from vs in ViewState.Keys.Cast < String > ()
where vs.Contains ( " dd " )
select ViewState.Values;
query.Single() <- 这里肯定是null.
ViewState.Add( " Info " , " Test " );
ViewState.Add ( "dd" , 11 );
// Get Info From ViewState
这里用以上方式就不行了。
var query = from vs in ViewState.Keys.Cast < String > ()
where vs.Contains ( " dd " )
select ViewState.Values;
query.Single() <- 这里肯定是null.
为啥呢,跟贴吧。:)