Google App Maker 如何应用自定义数据验证

Google App Maker how to apply custom data validation

App Maker 有默认验证和正则表达式验证,一旦发生错误就会突出显示字段。

我们需要进行自定义验证以检查模型中的重复记录。是否有任何检查验证的功能或我们是否需要执行任何脚本?

避免数据重复的最佳方法是使用 Cloud SQL 对您的表实施 'unique' 约束。

如果您不想使用 Cloud SQL 并想使用 Drive Tables,您可以使用锁、查询和模型事件手动模拟唯一约束:

// onCreate model event (actually it is onBeforeCreate)
// this events accepts about-to-create record as parameter
var lock = LockService.getScriptLock();
lock.waitLock(5000);

var query = app.models.MyModel.newQuery();
query.filters.SomeField._equals = record.SomeField;

var records = query.run();

if (records.length > 0) {
  throw new Error('Record with SomeField value equal to ' + record.SomeField +
                   ' already exists.');
}

lock.releaseLock();

你需要lock在这里防止其他线程同时创建违反你的唯一约束的记录。

然后你可以在createItem函数回调中处理UI的错误:

// create button onClick handler
widget.datasource.createItem({
  success: function(record) {
    // TODO
  },
  failure: function(error) {
    // TODO
  }
});