首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何防止基于另一个值的单元格发生更改,并显示有关该尝试的警告框?

如何防止基于另一个值的单元格发生更改,并显示有关该尝试的警告框?
EN

Stack Overflow用户
提问于 2019-07-20 01:00:38
回答 1查看 103关注 0票数 0

我有一个列(Col3),它有一个下拉列表。其中一个选项处于挂起状态。在下一个单元格(COL4)中是另一个下拉列表,NOTSUBMITTED是其中一个选项。

现在我想要的是,如果COL3有挂起,我应该不能改变COL4中的下一个单元格。简而言之,如果COL3有挂起,NOTSUBMITTED就不能改变。

然后显示一条弹出消息,说明有关这方面的一些信息。我尝试了以下操作,但它显示了消息,但我无法阻止正在更改的Col 4。我可以轻松地更改或删除第4列。

如何阻止这一切。

代码语言:javascript
复制
function onEdit(event){

      var actvCell = event.range.getSheet().getActiveCell();

     if(actvCell.getColumn() == 3 && event.value=="PENDING"){   
        Browser.msgBox('You cannot make changes if payment is pending');
     }
   }
EN

回答 1

Stack Overflow用户

发布于 2019-07-20 09:44:44

Problem

您希望根据活动单元格中的值停止编辑另一个单元格。

解决方案

您需要了解Protection类是如何为Spreadsheet服务工作的。算法如下:

如果活动单元格值为"pending“,则为

  1. ;如果活动单元格值为”pending“,则为->保护目标单元格,并将用户从保护编辑器中删除;如果活动单元格值为other,则为
  2. ;如果活动单元格值为other,则为->获取保护并进行筛选,以便在目标单元格上保留一个保护;
  3. 为删除对目标单元格的保护。

请记住,关于编辑权限有很多需要考虑的因素,最重要的是:

无论protections;

  • Domain-wide权限如何,电子表格的
  1. 所有者始终可以编辑所有内容。effect;
  2. Current用户(进行编辑的用户)不能从编辑器中移除;

有用链接

  1. Protectionreference;
  2. getProtections()方法reference(https://developers.google.com/apps-script/reference/spreadsheet/sheet#getProtections(ProtectionType%29);
  3. protect()方法reference;
  4. remove()方法reference;
  5. removeEditors()方法reference(https://developers.google.com/apps-script/reference/spreadsheet/protection#removeEditors(String%29);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57116786

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档