How do I restrict a trigger to a specific sheet/tab?

*爱你&永不变心* 提交于 2020-08-25 07:55:38

问题


I have written a script in google sheets that will change the time stamp in the selected cell anytime the entire spreadsheet is updated at all. However, I need the timestamp to only update when one single sheet(tab) is updated. Here is my current function:

function onEdit() {
  var sheetActive = SpreadsheetApp.getActiveSpreadsheet()
    .getSheetByName("Board")
    .getRange('A28')
    .setValue(new Date());
}

The name of the sheet(tab) that I want to check for an update in is "Input" and the specific cell in the tab is A1 if that matters.


回答1:


This is what you are looking for :

function onEdit(e) {

  var row = e.range.getRow();
  var col = e.range.getColumn();
  if ( e.source.getActiveSheet().getName() === "Input" && (row==1 && col==1) ){
 e.source.getSheetByName('Board').getRange('A28').setValue(new Date())      
  }
}



回答2:


The onEdit trigger triggers whenever any sheet/tab is edited. It cannot be restricted to a single sheet. However, even if it is triggered, it is possible to make it do nothing with a simple if and testing the event object that is sent on each edit, which contains the circumstances of the edit made.

Sample:

/**
 * @param {GoogleAppsScript.Events.SheetsOnEdit} param1
 */
function onEdit({ range: /*edited range*/ eRange }) {
  const restrictCell = 'A1',
    restrictToSheet = 'Input';
  if (
    eRange.getA1Notation() !== restrictCell ||
    eRange.getSheet().getName() !== restrictToSheet
  )
    return;
  SpreadsheetApp.getActiveSpreadsheet()
    .getSheetByName('Board')
    .getRange('A28')
    .setValue(new Date());
}



来源:https://stackoverflow.com/questions/63180391/how-do-i-restrict-a-trigger-to-a-specific-sheet-tab

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!