通过自定义 CellType 隐藏单元格中的 0 值

发布时间:2013/01/15 00:01 发布者:jian

返回博客中心

在 Spread for WinForms 中提供了FpSpread1.ActiveSheet.DisplayZero 属性,可以直接设置是否显示单元格中的 0 值,然而,在Spread for ASP.NET 中没有提供相应的属性,如果要实现同样的功能,我们可以通过自定义 CellType 来实现。

首先,创建自定义 CellType,重写 Format 和 Parse 方法:

    [Serializable]
    public class CDoubleCellType : FarPoint.Web.Spread.DoubleCellType
    {
        public override string Format(object obj)
        {
            if (obj != null && Convert.ToDouble(obj.ToString()) == 0)
            {
                return "";
            }
            else
            {
                return base.Format(obj);
            }
        }

        public override object Parse(string s)
        {
            if (s == "" || s == "0")
            {
                return 0;
            }
            else
            {
                return base.Parse(s);
            }
        }
    }

 

使用 CDoubleCellType 类型:

    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            FpSpread1.ActiveSheetView.RowCount = 10;
            FpSpread1.ActiveSheetView.ColumnCount = 10;
            FpSpread1.ActiveSheetView.Columns[0].CellType = new CDoubleCellType();
            FpSpread1.ActiveSheetView.Columns[0].Formula = "B1*C1";
            FpSpread1.ClientAutoCalculation = true;

            FpSpread1.ActiveSheetView.Columns[3].CellType = new CDoubleCellType();
        }
    }

 

源码下载:VS2010 + Spread .NET 6.0.3505 

 

DisplayZero_CellType.zip (10.84 kb)

 


关于葡萄城

赋能开发者!葡萄城是专业的集开发工具、商业智能解决方案、低代码开发平台于一身的软件和服务提供商,为超过 75% 的全球财富 500 强企业提供服务。葡萄城专注控件软件领域30年,希望通过模块化的开发控件、灵活的低代码应用开发平台等一系列开发工具、解决方案和服务,帮助开发者快速响应复杂多变的业务需求,最大程度地发挥开发者的才智和潜能,让开发者的 IT 人生更从容更美好。

了解详情,请访问葡萄城官网