永利最大(官方)网站

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

原创|其它|编辑:郝浩|2009-05-31 09:59:59.000|阅读 565 次

概述:本来教你如何用Asp.net扩展ExtJS,并提供详细原码。

#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>

上篇文章中在添加子类的时候利用的仍然是原来的老方法,创建了一个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,咱们站在两个巨人的头上干活还不更快吗?


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn

文章转载自:博客园

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP
PM娱乐城网络现金网站(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) PM娱乐城最大(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 永利外围最新(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 网络权威朗驰娱乐大全(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 永利真人网上足球(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) 利记最火十大网(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) boyu·博鱼权威网络足球(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新) PM娱乐城网上足球(官方)网站/网页版登录入口/手机版登录入口-最新版(已更新)