在客户端使用JS取到被锁定(Locked = true)的单元格

Spread中的Cell、Row和Column都提供了Locked属性,在后台代码中设置 Locked = true之后可以将相应区域的单元格进行锁定,不过在客户端中Spread并没有暴露相应的Locked属性,这就需要我们在客户端通过JS来判断单元格是否被锁定。

发布于 2012/11/14 00:00

在实际系统中,我们为了对某些单元格的数据进行保护,我们需要将这些单元格进行锁定,从而防止用户对其进行修改。

Spread中的Cell、Row和Column都提供了Locked属性,在后台代码中设置 Locked = true之后可以将相应区域的单元格进行锁定,不过在客户端中Spread并没有暴露相应的Locked属性,这就需要我们在客户端通过JS来判断单元格是否被锁定。

首先,我们在后台代码中设置[0,0]、[1,1]、[2,2]单元格的Locked为true,然后运行程序。通过浏览器中的“开发人员工具”我们可以看到,设置Locked = true单元格生成的HTML代码中有locked=”true”的属性,如下图:


我们就可以通过单元格是否有locked=”true”的属性设置来判断单元格是否被锁定了,代码如下:
 
var ss = FpSpread("FpSpread1");

    var table = document.getElementById("FpSpread1_viewport");

    var locked = table.rows[ss.GetActiveRow()].cells[ss.GetActiveCol()].attributes["locked"];

    if (locked != undefined && locked.value == "true") {

        document.getElementById("Text1").value = "【" + ss.GetActiveRow() + "," + ss.GetActiveCol() + "】 单元格被锁住了!!!";

    } else {

        document.getElementById("Text1").value = "【" + ss.GetActiveRow() + "," + ss.GetActiveCol() + "】 单元格没有被锁住!!!";

    }

复制代码
源码下载:VS2010 + Spread 6.0.3505

关于葡萄城

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

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

关注“葡萄城社区”

活字格低代码二维码

关注“活字格低代码”

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