强类型ASP.NET数据绑定改进“.NET研究”版

  相关文章:教你30秒打造强类型ASP.NET数据绑定强类型ASP.NET数据绑定改进版之第2版

  看了dragonpig写的“教你30秒打造强类型ASP.NET数据绑定”,眼前一亮,真是太给力了,原来还可以这样进行数据绑定。

  立即小试了一下,并进行了一些改进,目前已经应用于Home中的新闻栏目。下面分享一下改进心得。

  使用传统的ASP.NET数据绑定方法,有两个地方一直让人不爽:

  1) 缺少智能感知;

  2) 强制类型转换。

  先回味一下传统的ASP.NET数据绑定:

  看看上面的ToString(),(DateTime)...

  dragonpig的强类型绑定思路已经包含了解决这两个问题的方法,但在他展示的代码中,解决了第一个问题(智能感知),却忽略了第二个问题(强制类型转换),原始代码如下:

 
  
protected virtual object ExpHelper < TEntity, TREsult > (Func < TEntity, TREsult > func)
{
var itm
= GetDataItem();
return func((TEntity)itm);
}
protected object Stu < TResult > (Func < Student, TResult &上海闵行企业网站制作gt; func)
{
return ExpHe上海徐汇企业网站设计与制作lper < Student, TResult > (func);
}

  我在使用中发现还要进行强制类型转换,有点不爽,研究了一下,原来是object惹的祸,只要把上面代码中的两个object改为TResult,问题就解决了。

  另外,我把Stu方法名改为了Eval,感觉这样更友好。

  上代码:

 
  
protected virtual TREsult ExpHelper < TEntity, TREsult > (Func < TEntity, TREsult > func)
{
var item
= base .GetDataItem();
return func((TEntity)item);
}
protected TResult Eval < TResult > (Func < NewsInfo, TResult 上海网站建设tyle="color: #000000;">> func)
{
return ExpHelper < 上海徐汇企业网站制作st上海闵行企业网站设计与制作yle="color: #000000;">NewsInfo, TResult > (func);上海企业网站制作r />}

  有了“强类型ASP.NET数据绑定”之后的日子真美好...

  感谢dragonpig!你的分享太给力了!

转载于:https://www.cnblogs.com/waw/archive/2011/10/15/2213601.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值