是否可以在处理程序中使用静态变量?

时间:2012-10-05 17:29:49

标签: google-apps-script

我想创建一个跟踪按钮按下时间的脚本。众所周知,javascript缺乏对静态变量的支持,但这通常可以解决在目标函数之外定义变量的问题。

然而,在一个简单的谷歌脚本Web应用程序中,这对我不起作用。代码如下,它是模板Web应用程序的简单扩展。

任何人都知道如何实现这一目标?

这是Google应用程序的代码:

// Script-as-app template.

function doGet() {
  var app = UiApp.createApplication();
  var button = app.createButton('Click Me');
  app.add(button);
  var label = app.createLabel('The button was clicked.')
                 .setId('statusLabel')
                 .setVisible(false);
  app.add(label);
  myClickHandler.counter = 0;

  var handler = app.createServerHandler('myClickHandler');
  handler.addCallbackElement(label);
  button.addClickHandler(handler);

  return app;
}

function myClickHandler(e) {
  var app = UiApp.getActiveApplication();

  var label = app.getElementById('statusLabel');
  label.setVisible(true);
  label.setText('Clicked ' + myClickHandler.counter + ' times.')
  myClickHandler.counter++;
  //app.close();
  return app;
}

1 个答案:

答案 0 :(得分:2)

有几种可能的方法可以实现这一点,其中一种方法是使用隐藏的小部件来保存值。

function doGet(){
  var app = UiApp.createApplication();
  var button = app.createButton('Click Me');
  app.add(button);
  var counterValue = 0;
  var label = app.createLabel('The button was clicked.')
                 .setId('statusLabel')
                 .setVisible(false);
  var counter = app.createHidden('counter').setId('counter').setValue(counterValue)               
  app.add(label).add(counter);

  var handler = app.createServerHandler('myClickHandler');
  handler.addCallbackElement(counter);
  button.addClickHandler(handler);

  return app;
}

function myClickHandler(e) {
  var app = UiApp.getActiveApplication();

  var label = app.getElementById('statusLabel');
  label.setVisible(true);
  var counterValue = Number(e.parameter.counter)
  var counter = app.getElementById('counter')
  counterValue++;
  counter.setValue(counterValue.toString())
  label.setText('Clicked ' + counterValue + ' times.')
  return app; 
}