在Google apps脚本中,什么取代了Utilities.sleep()来防止双击

Within Google apps script, what replaces Utilities.sleep() to prevent double clicks?

本文关键字:sleep 双击 Utilities 脚本 apps Google 取代 什么      更新时间:2023-09-26

我在Google Docs Script里写一个插件。从侧边栏,它将信息写入文档,而不是电子表格。根据连接速度的不同,Doc会在1秒到5秒之间更新信息。

我的问题是用户双击。我可以禁用这个按钮;然而,脚本完成的时间不到一秒,而Doc在1秒内更新。完成的脚本启用按钮。用户再次单击按钮,脚本第一次尝试写入信息。最终的结果是一个双条目。

我的解决思路是:1。等待或暂停;一个回调函数或3。锁。

问题:回调:我不知道我可以使用什么事件/输入来告诉脚本现在解锁按钮。我可以做一个无限循环,不断检查直到博士更新,但这似乎不是一个可靠的解决方案。洛克:没有什么事情可以简单地等待。它可以等待函数可用,但这不是问题。问题是脚本相对于文档更新速度太快了。

任何想法吗?

谢谢。

我想到了这个解决方案:

每次调用脚本时,将文档的当前文本与上次调用时传递给脚本的文本进行比较。

一些伪代码:

var previousText = "";
function addEntry() {
    var body = DocumentApp.getActiveDocument().getBody();
    var currentText = body.getText();
    if (currentText === previousText) {
        // Enable button here
        return;
    }
    // Add entry to document AND currentText
    // ...
    // ...
    previousText = currentText; // Save the text for future checks
    // Enable button here
}
function onButtonClick(e) {
    addEntry();
    // Disable button here
}

我明白了。我没有意识到。withsucceshandler也等待Doc被更新。我假设它只等待. savessettings(设置)完成。现在在适当的时候使用SuccessHandler(enablesButton)来防止双击。

        google.script.run.withFailureHandler(onFailure).withSuccessHandler(enableButton)
               .saveSettings(settings);