代码改变世界

利用泛型委托增加代码的优雅 扩展ExtJS (2)

2009-05-30 00:21  午夜瞎想  阅读(1910)  评论(6编辑  收藏  举报

上篇文章中在添加子类的时候利用的仍然是原来的老方法,创建了一个List<Base>的集合,但这样的代码还不够紧凑,依然需要优化.

利用.net 自带的Action<T>委托可以方便的进一步优化代码.

aspx代码:

<% =this.HtmlExtJs().Init("ss", f => { f.title = "xxx"; f.varid = "xx"; f.width = 200; f.height = 200; })
    .Columns<ExtJS.Net.ExtButton>(c => { c.text = "xx"; })
    .Columns<ExtJS.Net.ExtButton>(c=>c.text="sasf")
    .ToRender()
%>
c#代码
public ExtWindow Columns<T>(Action<T> columnBuilder) where T:ExtJsBase, new()
{
   T t=new T() ;
   columnBuilder(t);
   Item.Add(t);
   return this;
}

 

生成的js代码依然如上文就不用列出来了.

可以看到利用Columns的方法依然不够优雅,既然所有的控件都是基于ExtJsBase的,直接用一个泛型数组来存里面的容器不是更好.

在基类里面增加ItemBuilder属性

private ItemBuilder<ExtJsBase> _items;


        public virtual ItemBuilder<ExtJsBase> Item
        {
            get {
                if (_items == null)
                    _items = new ItemBuilder<ExtJsBase>();
                return _items;
            }
            set { _items = value; }
        }

 

ItemBuilder类实现了IList<T> 并增加For方法

 public void For<A>(Action<A> propertySpecifier) where A:T,new()
        {
            A t=new A () ;
            propertySpecifier(t);
            
            _columns.Add(t);
           
        }

 

来实现添加Window容器里面的控件,实现后的aspx代码

<% =this.HtmlExtJs().Init("ss", f => { f.title = "xxx"; f.varid = "xx"; f.width = 200; f.height = 200; })
        .AddItem(item =>
        {
            item.For<ExtJS.Net.ExtButton>(f=>f.text="fds");
            item.For<ExtJS.Net.ExtJS.Form.ExtTextField>(f => f.fieldLabel = "111");
        })

    .ToRender()%>

 

这样看起来就美观多了smile_wink  基本的前台ExtJS结构就用如此模式实现了.终于不用写那么多麻烦js啦.利用vs智能提示的优势结合强大的Extjs,咱们站在两个巨人的头上干活还不更快吗?