在将数据输入此套件表单时,如何显示错误,以便我可以显示消息,例如下面针对重复ID记录抛出的消息?这是否需要在客户端脚本中完成,并且套件是否需要一个与客户端脚本链接的按钮来执行记录创建,然后重定向到另一个显示表单信息的suitelet?似乎必须有一种更简单的方法来显示错误客户端而无需重定向两次。
Suitelet示例:
define([ 'N/ui/serverWidget', 'N/record', 'N/cache'],
function( serverWidget, record, cache) {
function onRequest(context) {
var func = 'Suitelet';
var request = context.request;
if(request.method == 'GET'){
try{
var form = serverWidget.createForm({
title: 'Add sample data'
});
var idField = form.addField({
id: 'custpage_sample_id',
type: serverWidget.FieldType.TEXT,
label: 'ID'
});
idField.isMandatory = true;
form.addSubmitButton({
label: 'Submit'
});
context.response.writePage(form);
}
catch(e){
log.error(func, JSON.stringify(e));
}
}
else {
try{
var id = request.parameters.custpage_id;
log.debug(func, id);
if(Id){
var existing = getExistingId(Id);
if(!existing){
var custID = createIdRecord(id);
} else {
throw 'ID already exists '+ id;
}
}
var form = serverWidget.createForm({
title: 'Form Submitted'
});
var displayField = form.addField({
id: 'custpage_my_display',
type: serverWidget.FieldType.LONGTEXT,
label: 'Display Data'
});
displayField.defaultValue = "ID: " + id;
context.response.writePage(form);
}
catch(e){
log.error(func, JSON.stringify(e));
}
}
}
return {
onRequest: onRequest
};
});
除“提交”按钮外,您不需要其他按钮。但是您需要将您的suitelet与客户端脚本链接:
form.clientScriptFileId = client_script_file_id;
您的客户端脚本不需要部署,您只需要在文件柜上。用户单击提交按钮后,将在链接到suitelet的客户端脚本上触发saveRecord事件。
function saveRecord(context) {
//put your duplicate id logic validation here
if(you want to proceed){
return true;
}else {
alert('duplicate id'); // or display an hidden field with any error message
return false;
}
}