如何使用 Suitescript 2.0 在 netsuite 中设置 RESTlet 的日期
How to set date for RESTlet in netsuite with Suitescript 2.0
我在通过 RESTlet 创建电话 activity 时遇到错误,即使我发送了正确的格式。
Invalid date value (must be M/D/YYYY)
它在 Suitescript 1.0 中工作正常。
Phonecall 有许多标准日期字段,也可以有自定义日期字段。
如果需要将这些日期字段转换为 Restlet 可接受的格式,需要识别所有日期和时间类型字段。
还有其他方法可以进行吗?
JSON
{
"title":"test",
"startdate":"01/08/2019",
"resourceType":"phonecall"
}
它在 suitescript 1.0 中工作正常
function post(datain) {
var record = nlapiCreateRecord(datain.resourceType);
for (var fieldname in datain) {
if (datain.hasOwnProperty(fieldname)) {
if (fieldname != 'resourceType' && fieldname != 'id') {
var value = datain[fieldname];
record.setFieldValue(fieldname, value);
}
}
}
var recordId = nlapiSubmitRecord(record);
nlapiLogExecution('DEBUG', 'id=' + recordId);
var nlobj = nlapiLoadRecord(datain.resourceType, recordId);
return nlobj;
}
不适用于 Suitescript 2.0
/**
*@NApiVersion 2.x
*@NScriptType Restlet
*/
define(['N/record'],function(record) {
function post(context) {
var resourceType = context.resourceType
delete context.resourceType
var objectRecord = record.create({
type: resourceType
});
for (var fldName in context) {
if (context.hasOwnProperty(fldName)) {
objectRecord.setValue(fldName, context[fldName]);
}
}
var createdId = objectRecord.save({});
return getById(resourceType, createdId);
}
function getById(resourceType, recordId) {
if (recordId != undefined) {
var response = record.load({
type: resourceType,
id: recordId
});
return response;
}
}
return {
post: post
};
});
setValue()
对于 SS2.0 中的日期字段,需要 JavaScript 日期对象作为值而不是字符串。所以你可以这样做:
for (var fldName in context) {
if (context.hasOwnProperty(fldName)) {
if (fldName === 'startdate') {
objectRecord.setValue(fldname, new Date(context[fldName]));
}
objectRecord.setValue(fldName, context[fldName]);
}
}
看起来您正在尝试创建通用记录更新API,因此也许检查一下字段名称 'contains' 日期然后转换它。
if (fldName.indexOf('date') >= 0) {
objectRecord.setValue(fldname, new Date(context[fldName]));
}
编辑:您可以在设置值之前进行一些字段类型检测:
var field = objectRecord.getField{ fieldId: fldName });
if (field.type === 'date') {
objectRecord.setValue(fldName, new Date(context[fldName]));
}
我在自定义记录的 beforeSubmit 事件中设置日期字段(使用 Javascript 日期对象作为值),并在 CSV 导入中遇到相同的错误 Invalid date value (must be M/D/YYYY).
经过反复试验,我能够通过在 setValue 中添加 ignoreFieldChange: true 来设置日期值。
newRecord.setValue({ fieldId: key, value: new Date(), ignoreFieldChange: true });
(请注意,当我使用 CSV 导入导入自定义记录并在 beforeSubmit UserEvent 函数中设置日期字段时,我遇到了这个错误。)
我在通过 RESTlet 创建电话 activity 时遇到错误,即使我发送了正确的格式。
Invalid date value (must be M/D/YYYY)
它在 Suitescript 1.0 中工作正常。 Phonecall 有许多标准日期字段,也可以有自定义日期字段。
如果需要将这些日期字段转换为 Restlet 可接受的格式,需要识别所有日期和时间类型字段。
还有其他方法可以进行吗?
JSON
{
"title":"test",
"startdate":"01/08/2019",
"resourceType":"phonecall"
}
它在 suitescript 1.0 中工作正常
function post(datain) {
var record = nlapiCreateRecord(datain.resourceType);
for (var fieldname in datain) {
if (datain.hasOwnProperty(fieldname)) {
if (fieldname != 'resourceType' && fieldname != 'id') {
var value = datain[fieldname];
record.setFieldValue(fieldname, value);
}
}
}
var recordId = nlapiSubmitRecord(record);
nlapiLogExecution('DEBUG', 'id=' + recordId);
var nlobj = nlapiLoadRecord(datain.resourceType, recordId);
return nlobj;
}
不适用于 Suitescript 2.0
/**
*@NApiVersion 2.x
*@NScriptType Restlet
*/
define(['N/record'],function(record) {
function post(context) {
var resourceType = context.resourceType
delete context.resourceType
var objectRecord = record.create({
type: resourceType
});
for (var fldName in context) {
if (context.hasOwnProperty(fldName)) {
objectRecord.setValue(fldName, context[fldName]);
}
}
var createdId = objectRecord.save({});
return getById(resourceType, createdId);
}
function getById(resourceType, recordId) {
if (recordId != undefined) {
var response = record.load({
type: resourceType,
id: recordId
});
return response;
}
}
return {
post: post
};
});
setValue()
对于 SS2.0 中的日期字段,需要 JavaScript 日期对象作为值而不是字符串。所以你可以这样做:
for (var fldName in context) {
if (context.hasOwnProperty(fldName)) {
if (fldName === 'startdate') {
objectRecord.setValue(fldname, new Date(context[fldName]));
}
objectRecord.setValue(fldName, context[fldName]);
}
}
看起来您正在尝试创建通用记录更新API,因此也许检查一下字段名称 'contains' 日期然后转换它。
if (fldName.indexOf('date') >= 0) {
objectRecord.setValue(fldname, new Date(context[fldName]));
}
编辑:您可以在设置值之前进行一些字段类型检测:
var field = objectRecord.getField{ fieldId: fldName });
if (field.type === 'date') {
objectRecord.setValue(fldName, new Date(context[fldName]));
}
我在自定义记录的 beforeSubmit 事件中设置日期字段(使用 Javascript 日期对象作为值),并在 CSV 导入中遇到相同的错误 Invalid date value (must be M/D/YYYY).
经过反复试验,我能够通过在 setValue 中添加 ignoreFieldChange: true 来设置日期值。
newRecord.setValue({ fieldId: key, value: new Date(), ignoreFieldChange: true });
(请注意,当我使用 CSV 导入导入自定义记录并在 beforeSubmit UserEvent 函数中设置日期字段时,我遇到了这个错误。)