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

简介:
虽然这一篇已经是“下”了,但是我并没有研究清楚“自定义控件设计时如何把属性写入到aspx中”这个问题。
不过,我选择了另外一条路,做了点手脚,让控件把属性写入到aspx中去了。

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

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

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

主要代码如下:
 1          /// <summary>
 2        /// 已重写。获取表示 GridView 控件中列字段的 DataControlField 对象的集合。
 3        /// 重写以实现设计时把英文表头转为中文、列重新排序、列宽度调整
 4        /// </summary>

 5          public  override DataControlFieldCollection Columns
 6          {
 7            get
 8            {
 9                DataControlFieldCollection cs = base.Columns;
10                if (cs == null || cs.Count < 1 || Site == null || Site.Component == nullreturn cs;
11                SetDefaultStype(cs);
12                NGridView ng = Site.Component as NGridView;
13                if (ng == null || !ng.DesignMode) return cs;
14                try
15                {
16                    if (ng.GetHashCode() == this.GetHashCode())
17                    {
18                        //if (isEntryCreating || !(isChanged || AutoGenerateDeleteButton || AutoGenerateEditButton || AutoGenerateSelectButton)) return cs;
19                        if (isEntryCreating) return cs;
20                        //SetDefaultStype(cs);
21                        if (!isChanged) return cs;
22                        isEntryCreating = true;
23                        CreateEntryColumns(cs);
24                    }

25                }

26                catch (Exception ex) { MessageBox.Show(ex.Message, "NGridView"); }
27                finally
28                {
29                    isEntryCreating = false;
30                    isChanged = false;
31                }

32                return cs;
33            }

34        }

35

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

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

最后的结果,还挺令人满意的。目前正在想法子重载DetailView和FormView
我不相信神话,我只相信汗水!我不相信命运,我只相信双手!

本文转自大石头博客园博客,原文链接:http://www.cnblogs.com/nnhy/archive/2007/04/20/721558.html,如需转载请自行联系原作者
目录
相关文章
|
C# Windows
2000条你应知的WPF小姿势 基础篇<78-81 Dialog/Location/WPF设备无关性>
2000条你应知的WPF小姿势 基础篇<78-81 Dialog/Location/WPF设备无关性>
101 0
|
5月前
|
容器 C# 开发者
XAML语言大揭秘:WPF标记的魅力所在,让你轻松实现界面与逻辑分离,告别复杂代码!
【8月更文挑战第31天】XAML提供了一种直观且易于维护的界面设计方式,使得开发者可以专注于逻辑和业务代码的编写,而无需关心界面细节。通过数据绑定、布局管理和动画效果等特性,XAML可以实现丰富的界面交互和视觉效果。在实际开发过程中,开发者应根据具体需求选择合适的技术方案,以确保应用程序能够满足用户的需求。希望本文的内容能够帮助您在WPF应用程序开发中更好地利用XAML语言。
54 0
QtApplets-自定义控件-5-属性研究
QtApplets-自定义控件-5-属性研究
125 0
QtApplets-自定义控件-5-属性研究
QtApplets-自定义控件-4-属性研究
QtApplets-自定义控件-4-属性研究
147 0
QtApplets-自定义控件-4-属性研究
QtApplets-自定义控件-7-属性研究
QtApplets-自定义控件-7-属性研究
111 0
QtApplets-自定义控件-7-属性研究
|
C#
艾伟_转载:WPF/Silverlight陷阱:XAML自定义控件的嵌套内容无法通过名称访问
为了说明这个问题,假定我们需要实现一个具有特殊功能的按钮控件。编写Xaml文件如下: Button> 对 Code Behind类,唯一的改动是把向导生成的基类从UserControl改成Button: public partial class XamlButton : Button{    ...
1086 0
|
C#
[WPF 容易忽视的细节] —— x:Name与Name属性
原文:[WPF 容易忽视的细节] —— x:Name与Name属性 一、前言 WPF使用XAML来对界面进行编写,界面与后台逻辑分离。我们也可以写Style、Trigger来实现一些界面效果, 这些都是通过Name来定位控件的,例如Setter.TargetName、Trigger.SourceName和Binding的ElementName等。
1135 0
|
C# C++
WPF编游戏系列 之四 用户控件
原文:WPF编游戏系列 之四 用户控件        在上一篇《WPF编游戏系列 之三 物品清单》中,对物品清单进行了演示,其中反复用到了同一组控件(如下图),而且 颜昌钢也指出在3.2.2中使用的C#代码过多,其实我在写这些代码时也有同感,的确很繁琐也不好维护。
621 0