在应用脚本中传递参数

时间:2018-10-02 17:20:25

标签: google-apps-script parameter-passing google-apps-script-editor

基于https://www.plivo.com/blog/Send-templatized-SMS-from-a-Google-spreadsheet-using-Plivo-SMS-API/,我有以下代码:

data = {
    "SOURCE" : "+1234567890",
    "DESTINATION" : "+2345678901",
    "FIRST_NAME" : "Jane",
    "LAST_NAME" : "Doe",
    "COUPON" : "DUMMY20",
    "STORE" : "PLIVO",
    "DISCOUNT" : "20",
}

template_data = "Hi   FIRST_NAME , your coupon code for discount of % purchase at  is "

function createMessage(data,template_data){
  Logger.log(data);

  for (var key in data) {
    Logger.log(key);

    if (data.hasOwnProperty(key)) {
      template_data = template_data.replace(new RegExp('+key+', 'gi'), data[key]);
    }
  }
  Logger.log(template_data);
  return template_data;
}

当我运行createMessage并查看日志时,我看到:

[18-10-02 13:19:03:139 EDT] undefined
[18-10-02 13:19:03:139 EDT] undefined

这向我建议参数未传递到函数中。我在做什么错了?

1 个答案:

答案 0 :(得分:1)

在“脚本编辑器”中运行功能不会将参数传递给该功能。当前,您的项目的全局命名空间中有3个用户对象(包括Google的其他对象):

  • createMessage(一个函数对象)
  • template_data(字符串)
  • data(一个对象)。

function createMessage(data, template_data)行将对象createMessage声明为函数对象,并表示传递给函数的前两个参数在函数范围内被称为 { {1}}和data。这些函数范围的参数声明遮盖了任何更远的声明(例如,来自全局范围或封闭函数范围)。

然后的解决方案是编写一个实际执行的“驱动程序函数”,在其中定义被调用函数的输入参数,或者从函数调用中删除这些参数:

template_data

避免参考阴影:

var data = {...}; // global var
var template_data = {...}; // global var
function driver() {
  createMessage(data, template_data); // uses the globally scoped `data` & `template_data` objects
  var otherdata = 1,
      otherTemplate = 2;
  createMessage(otherdata, otherTemplate); // uses the function-scoped `otherdata` and `template_data` objects
}
function createMessage(someData, someTemplate) {
  Logger.log(someData);
  Logger.log(arguments[0]); // equivalent to the above line.
  // ...
}

为解决这种情况-阻止通过脚本编辑器手动执行需要参数的功能-我通常会通过在名称function createMessage() { // removed `arguments` reference binding Logger.log(data); // accesses global-scope `data` object because there is no `data` reference in the nearest scope 后面添加_来使这些函数私有化

参考文献: