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

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

发布于 2013/01/15 00:00

在 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)

 

关于葡萄城

葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的用户社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。

推荐相关案例
推荐相关资源
关注微信
葡萄城社区二维码

关注“葡萄城社区”

加微信获取技术资讯

加微信获取技术资讯

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态