文档章节

自定义模板列在 PostBack 后消失的问题

夏至如沫
 夏至如沫
发布于 2013/07/03 17:16
字数 1293
阅读 110
收藏 0

昨天写的自定义模板今天再去做测试的时候玩不转了主要是俩个问题,同样都发生在页面回发时:


  1. 没有为该对象定义无参数的构造函数

点击画面任何需要PostBack 的按钮就会抛出一个异常:

在此输入图片描述

眨眼一看还以为是JS的错误,然后突然意识到可能是跟序列化有关。因为之前在使用需要跨页传递Model或者使用 Serializable 标记的类时经常出现缺少默认构造的异常提示,然后就只能乖乖添加一个空的构造函数。好吧,还是去默默修改昨天继承 ITemplate 的两个类( ItemTemplateLinkBtnItemTemplateLabel) ,为它们添加默认的空构造。如下:

<!-- lang: c# -->
    #region Item Template for Link Button
/// <summary>
/// 为超链接创建模板元素
/// </summary>
public class ItemTemplateLinkBtn : ITemplate
{
    /// <summary>
    /// 序列化使用
    /// </summary>
    public ItemTemplateLinkBtn() { }
    /// <summary>
    /// 构造函数
    /// </summary>
    /// <param name="ColText">列名</param>
    /// <param name="navigateURL">URL格式化字符串</param>
    /// <param name="mGuid">绑定的列名(暂时只支持一个)</param>
    public ItemTemplateLinkBtn(string ColText, string navigateURL, string ColumnGuid)
    {
        this.strColumnText = ColText;
        this.FormatString = navigateURL;
        this.FieldGuid = ColumnGuid;
    }
...........

#region Item Template for Label
/// <summary>
/// 创建标签模板
/// </summary>
public class ItemTemplateLabel : ITemplate
{
    /// <summary>
    ///  序列化
    /// </summary>
    public ItemTemplateLabel() { }
......

此时再运行,谢天谢地,终于过去,已经加载出新的页面的,但是BUG来了。。。


2.自定义的模板列在PostBack 后消失

初始加载的页面(模板列和普通列都正常)

在此输入图片描述

翻页或者查询等动作PostBack后的页面(模板列好像消失了一样)

在此输入图片描述

仔细去看的时候发现其实模板列并没有消失,只是我们定义的中间控件消失了,但是同样是动态创建的 BoundField 类型的普通列并没有异常,猜想应该是我们自定义的控件状态没有被保存,而BoundField 的内容可能会包含某种状态保存的标记(像 Serializable 序列化标记一样)而被.Net 框架保存处理了。 然后我们在 BoundField F12 到它的定义

<!-- lang: c# -->
// 摘要:
//     表示数据绑定控件中作为文本显示的字段。
public class BoundField : DataControlField

在这里看不到我们想要的,但是看到他的父类 DataControlField ,看到带有 Data 这四个字的时候我已经觉得猜对了一半,果然在DataControlField 的定义中:

<!-- lang: c# -->
public abstract class DataControlField : IStateManager, IDataSourceViewSchemaAccessor 

找到了

在此输入图片描述

然后返回 BoundField 的定义果然发现已经重载了所有 IStateManager 声明的方法

在此输入图片描述

这下咱们的想法验证了,现在有俩条路可走,要么去实现 IStateManager ,要么人为地更新状态。前者,对不起,一切关于框架的东东对于我这个菜鸟太难了,凑个热闹看下意思,膜拜下大神们的神来之笔就好了,那还是挑个简单的吧。既然模板列的状态丢了那只要保证每次更新模板列的定义就可以了。所以我们被迫每次都要在数据绑定前重新定义模板列的内容。建议在GrideView_Init 或者 Page_Init 事件中创建。

<!-- lang: c# -->
        #region 构造和初始化
    /// <summary>
    /// 数据加载
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            // 是否可以编辑
            if (_TableScheme.ReadOnly == true)
                BtnEdit.Visible = false;
            // 数据绑定方法
            PageGrideDefaultLoad();
        }
        // 各行变色
        ExcuteJs(this, "gridviewColor('gdvPageView')");
    }
    /// <summary>
    /// 初始化表格
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    protected void gdvPageView_Init(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            // 数据表结构只缓存一次
            PageID = Request.QueryString["PAGEID"];
            _TableScheme = LibSchemeBLL.Instance.GenerateTableScheme(PageID);
        }
        // 生成列
        GenerateGrideColumn();
    }
    #endregion

这些做完,测试一下,终于可以正常了!


跟序列化相关的

其实如果把这俩个问题调整一下顺序,先解决显示的问题,把动态列的定义放在 Init 中实现时,第一个序列化的问题就没有了,至于什么原因我就解释不清楚了。大概是因为恢复控件状态要利用类似反序列化的机制吧。


现在静下心来总结一下,小小的模板列其实里面包含了太多的东西,从数据容器到控件,从数据绑定到控件赋值,然后就是PostBack之间状态的保存。我觉得或许只是一个最简单的Lable也是要包含这么多东东的,突然想到 TextBox 在 ReadOnly 后前台的赋值后台也是读不到了,不也是控件状态的问题吗?

平常用惯了简单上手的东西,根本认识不到即便是最简单的控件都是 大神们 精心封装好的!再次膜拜一下在程序员道路上的先烈们!

不禁想起这段很在流行的那首诗:

<!-- lang: html -->
锄禾日当午,汗滴禾下土,谁知盘中餐,粒粒皆辛苦!

问,锄禾跟几个人发生了不正当关系?不禁感概一粒米中竟然有那么多关系, 所以嘛: 万恶的 System.Web.UI.WebControls 你到底有多少关系呀!!!

© 著作权归作者所有

共有 人打赏支持
夏至如沫

夏至如沫

粉丝 11
博文 38
码字总数 23667
作品 0
郑州
后端工程师
私信 提问
为 ASP.NET Datagrid 创建自定义列

Marcie Robillard DatagridGirl.com 2003 年 9 月 简介 不得不承认,为 Microsoft® ASP.NET 编写 Datagrid 代码包括大量的重复工作。尽管我深受该控件的困扰,但我还是不断寻找简化这类任务...

晨曦之光
2012/03/09
541
0
affiliate pay的相关疑问

1、目前使用的mobking.biz上面postback回调后,转化记录需要审批,我们是否也需要审批? 2、如果广告这边的事件对应的支付方式(Payout Model)设置为了CPS或CPA+CPS,那么转化过程中支付金额怎...

TabZhu
2017/05/02
0
1
FineUI v3.3.1 发布了!

关于FineUI 基于 ExtJS 的专业 ASP.NET 控件库。 FineUI的使命 创建 No JavaScript,No CSS,No UpdatePanel,No ViewState,No WebServices 的网站应用程序。 支持的浏览器 IE 7.0+、Firef...

三生石上
2013/07/29
3K
4
我的合同以及我的员工逻辑整理及介绍

我的合同: 合同列表: 此界面中的列表数据是显示了所有状态为SECONDARYPASSED的合同 《1.双击“客户名称”、“所属行业”、“客户规模”、“产品类型”均可弹出[客户名片模式框],在此模式框中...

firefly_caomeng
2017/01/31
1
0
实操利用PowerPoint制作倒计时

褐色记事本封面背景ppt素材  1、新建一个空白板式的ppt,选择合适的模板,输入题目艺术字“倒计时”和“时间到”和相应的文字“时间还剩秒”,调节字体和大小位置。在利用自选图形里的圆角...

ppt模板下载空间
2015/08/29
25
0

没有更多内容

加载失败,请刷新页面

加载更多

JavaScript 继承使用解析

继承,通俗地说,之前你写过一些类,这些类中有一些是而你现在要写的类的功能的子集或者基本相同,那么你不用完全重新写一个新的类,你可以把之前写的类拿过来使用.这样的一种代码重用过程就叫做继...

前端攻城小牛
15分钟前
0
0
深入解析JavaScript 原型继承

JavaScript 原型继承,学习js面向对象的朋友可以看看。十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。 Object.prototype JavaScript是...

前端攻城老湿
17分钟前
0
0
2018阿里云双12——年末钜惠,低至2折

活动链接地址:https://m.aliyun.com/act/team1212/?params=N.JlJCGqQNL4

城市之雾
17分钟前
0
0
VMware前路难测,多个厂家群雄逐鹿

导读 以VMware为例,虚拟机巨头公布了第二财季报告所示,它第二财季收入同比增长13%,达到了21.7亿美元,而且该公司收入和每股收益均超出预期。 在人们高谈Salesforce、亚马逊等新兴云计算厂...

问题终结者
19分钟前
0
0
Vuex的初探与实战小结

1.概述 每一个 Vuex 应用的核心就是 store(仓库)。“store”基本上就是一个容器,它包含着你的应用中大部分的状态 (state)。 Vuex 和单纯的全局对象有以下两点不同: 1.Vuex 的状态存储是响...

peakedness丶
29分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部