在以这种Suitelet形式输入数据时,如何显示错误,以便显示诸如以下有关重复ID记录的消息?这是否需要在客户端脚本中完成,并且Suitelet是否需要具有与客户端脚本链接的按钮,以执行记录创建,然后重定向到另一个显示表单信息的Suitet?似乎必须有一种更简单的方法来在客户端显示错误而无需重新定向两次。
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
};
});
答案 0 :(得分:2)
除了“提交”按钮外,您不需要其他按钮。但是,您确实需要将Suitet与客户端脚本链接:
form.clientScriptFileId = client_script_file_id;
您的客户端脚本不需要部署,只需要在文件柜中使用即可。用户单击“提交”按钮后,将在链接到套件的客户端脚本上触发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;
}
}