前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >关于自定义控件设计时如何把属性写入aspx中的研究(下)

关于自定义控件设计时如何把属性写入aspx中的研究(下)

作者头像
大石头
发布2018-01-15 10:38:34
2.1K0
发布2018-01-15 10:38:34
举报
文章被收录于专栏:智能大石头智能大石头

虽然这一篇已经是“下”了,但是我并没有研究清楚“自定义控件设计时如何把属性写入到aspx中”这个问题。

不过,我选择了另外一条路,做了点手脚,让控件把属性写入到aspx中去了。

其实,即使有人肯定的告诉我,在上篇中提到的ControlSerializer类的SerializeControl方法就是用于把控件属性写入到aspx中去的,我也实在没办法利用它,它的位置太“深”了。

我是通过重写GridView的Columns属性来实现的。我当时想,即使实例A(如果不明白实例A指什么,请看上篇https://cloud.tencent.com/developer/article/1019910)从来不调用CreateColumns方法,但是,它肯定要调用Columns属性吧。重载该属性,并输出日志,果然,有很少的几次调用。不过,已经够了。

我的做法就是,在这个属性的get方法里面,强制改变各列的属性,再返回。设计器在生成控件的aspx时,至少要读取Columns来生成各个列吧。

主要代码如下:

代码语言:javascript
复制
/// <summary>
        /// 已重写。获取表示 GridView 控件中列字段的 DataControlField 对象的集合。
        /// 重写以实现设计时把英文表头转为中文、列重新排序、列宽度调整
        /// </summary>
        public override DataControlFieldCollection Columns
        {
            get
            {
                DataControlFieldCollection cs = base.Columns;
                if (cs == null || cs.Count < 1 || Site == null || Site.Component == null) return cs;
                SetDefaultStype(cs);
                NGridView ng = Site.Component as NGridView;
                if (ng == null || !ng.DesignMode) return cs;
                try
                {
                    if (ng.GetHashCode() == this.GetHashCode())
                    {
                        //if (isEntryCreating || !(isChanged || AutoGenerateDeleteButton || AutoGenerateEditButton || AutoGenerateSelectButton)) return cs;
                        if (isEntryCreating) return cs;
                        //SetDefaultStype(cs);
                        if (!isChanged) return cs;
                        isEntryCreating = true;
                        CreateEntryColumns(cs);
                    }
                }
                catch (Exception ex) { MessageBox.Show(ex.Message, "NGridView"); }
                finally
                {
                    isEntryCreating = false;
                    isChanged = false;
                }
                return cs;
            }
        }

CreateEntryColumns就是我用来改变列属性的方法,之前的几个判断,是为了防止列属性被频繁改变。我只需要在绑定数据源之后改变就可以了。

语句if (ng.GetHashCode() == this.GetHashCode()),通过判断当前对象和A对象的HashCode,来判断是否是同一个实例,也就是说,我要求这个重载,只在实例A中生效。

最后的结果,还挺令人满意的。目前正在想法子重载DetailView和FormView

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2007-04-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档