ディスカッション
AIを用いた自動化で請求書処理を合理化
AIを用いた考察を使用して、計画と予測を迅速化
SuiteWorldまであと41日となりました。以下の最新情報をご確認ください。
アジェンダビルダー公開
SuiteWorld On Airの登録受付開始
新しいNetSuite Prompt Studioコンテスト
その他の最新情報も!
詳細はこのスレッドでご確認ください!
nlapiGetFieldValue('shipaddressee') > エラー > 解析中の再帰が深すぎる
適用
製品: NetSuite 2022.1
シナリオ
注文書の配送先宛先のフィールドを取得する時に、予期しないエラーが発生しています。
var addressee = nlapiGetFieldValue('shipaddressee');
エラーメッセージ「Error: Error: Too deep recursion while parsing」が表示されます。
フィールドID shipaddresseeは、2017.1レコードブラウザ以降、サポートされなくなりました。したがって、フィールドID shipaddresseeを使用することは推奨されません。
解決策
注文書の配送先を取得する方法として、配送先フィールドのサブレコードにアクセスすることをお勧めします。
nlapiViewSubrecord('shippingaddress')
上記コードでnlobjSubrecordのアドレスサブレコードを返します。nlobjSubrecordから値を取得する場合、nlobjRecordのメソッドを利用できます。今回、getFieldValueのメソッドを利用します。
nlapiViewSubrecord('shippingaddress').getFieldValue('addressee')
つまり、以下のようにスクリプトの修正は必要です。
修正前:
var addressee = nlapiGetFieldValue('shipaddressee');
修正後:
var addressee = nlapiViewSubrecord('shippingaddress').getFieldValue('addressee');
免責事項
ここに記載されているサンプルコードは、法律で認められている最大限の範囲で、いかなる種類の保証もなく、「現状のまま」で提供されています。Oracle+NetSuite社は、開発者がそれぞれの開発プラットフォームにサンプルコードを実装したり、独自の Web サーバー構成を使用したりする際に、個々の成功を保証するものではありません。
Oracle + NetSuite社は、サンプルコードに関連するデータまたは情報の使用、使用結果、正確性、適時性または完全性に関して、いかなる保証も行わず、表明もしません。Oracle + NetSuite社は、明示的にも黙示的にもすべての保証を放棄し、特に、商品性、特定目的への適合性、およびコード、またはそれに関連するサービスやソフトウェアに関連する保証を放棄します。
Oracle + NetSuite社は、本サンプルコードに関連してお客様または他者が行った行為に起因するいかなる種類の直接的、間接的または結果的な損害または費用についても責任を負いません。