如何在 Suitelet post 上下文中显示客户端警报?
How to display client-side alerts in Suitelet post context?
如何在向该 suitelet 表单输入数据时显示错误,以便我可以显示诸如下面抛出的关于重复 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
};
});
除了 'submit' 按钮之外,您不需要其他按钮。但是你确实需要 link 你的 suitelet 有一个客户端脚本:
form.clientScriptFileId = client_script_file_id;
您的客户端脚本不需要部署,您只需要放在文件柜上即可。一旦用户单击提交按钮,就会在客户端脚本上触发 saveRecord 事件 linked 到 suitelet。
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;
}
}
如何在向该 suitelet 表单输入数据时显示错误,以便我可以显示诸如下面抛出的关于重复 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
};
});
除了 'submit' 按钮之外,您不需要其他按钮。但是你确实需要 link 你的 suitelet 有一个客户端脚本:
form.clientScriptFileId = client_script_file_id;
您的客户端脚本不需要部署,您只需要放在文件柜上即可。一旦用户单击提交按钮,就会在客户端脚本上触发 saveRecord 事件 linked 到 suitelet。
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;
}
}