google-apps-script - 谷歌脚本依赖下拉列表 - 不工作
问题描述
所以我在关注谷歌表 - 相关下拉列表教程,可以在这里查看:
*https://www.youtube.com/watch?v=s-I8Z4nTDak&t=45s*
我现在已经完成了 3 次教程并尝试了很多东西......但我仍然无法让脚本正常工作
问题:当我从 D 列(标记为 - 类别)中选择一个项目时,在“主”表上,E 列的相关下拉列表出现,但未显示匹配的相应选项。相反,从属下拉列表只显示一个空白??
任何帮助将不胜感激!
我的谷歌表:
https://docs.google.com/spreadsheets/d/1DOF_CECC_c28dmIhdaYaG0KBn8fqdZ-qqGoiTxEMZo8/edit?usp=sharing
脚本代码:
var ws = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("master");
var wsOptions = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("options");
var options = wsOptions.getRange(2,3,wsOptions.getLastRow()-1,4).getValues();
function myfunction() {
var list = ["a","b","g"];
var cell = ws.getRange("E2");
applyValidationToCell(list,cell);
}
function onEdit(e){
var activeCell = e.range;
var val = activeCell.getValue();
var r = activeCell.getRow();
var c = activeCell.getColumn();
var wsName = activeCell.getSheet().getName();
if(wsName == "master" && c === 4 && r > 1){
var filteredOptions = options.filter(function(o){ return o[2] === val });
var listToApply = filteredOptions.map(function(o){ return o[3] });
var cell = ws.getRange(r, 5);
applyValidationToCell(listToApply,cell);
}
}
function applyValidationToCell(list,cell){
var rule = SpreadsheetApp
.newDataValidation()
.requireValueInList(list)
.setAllowInvalid(false)
.build();
cell.setDataValidation(rule);
}