2018-02-11 20:59:01 +09:00
<!--
Copyright JS Foundation and other contributors, http://js.foundation
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
2020-01-15 11:40:48 +09:00
< script type = "text/html" data-help-name = "switch" >
2018-02-11 20:59:01 +09:00
< p > プロパティの値によってメッセージの振り分けを行います。< / p >
< h3 > 詳細< / h3 >
< p > 受信したメッセージに対し、指定されたルールを順に評価し、マッチしたルールに対応する出力ポートにメッセージを送出します。< / p >
< p > 最初にルールがマッチしたところで評価を止めることも可能です。< / p >
2019-06-07 21:39:12 +09:00
< p > 評価ルールには、メッセージプロパティ、フローコンテキスト/グローバルコンテキストのプロパティ、環境変数、JSONata式の評価結果が利用できます。< / p >
2019-02-08 09:26:11 +09:00
< h4 > ルール< / h4 >
2018-02-11 20:59:01 +09:00
< p > 振り分けルールは以下の4つに分類されます。< / p >
< ol >
< li > < b > 値(value)< / b > ルール - 指定したプロパティに対して評価< / li >
< li > < b > 列(sequence)< / b > ルール - メッセージ列に対して適用(メッセージ列はsplitノ ードなどで生成)< / li >
< li > < b > JSONata式< / b > - メッセージ全体に対して評価を行い、結果が真の場合にマッチ< / li >
< li > < b > その他< / b > - これより前のルールにマッチするものがなかった場合に適用< / li >
< / ol >
2019-02-08 09:26:11 +09:00
< h4 > 注釈< / h4 >
2018-07-20 13:35:24 +09:00
< p > < code > is true/false< / code > と< code > is null< / code > のルールは、型に対して厳密な比較を行います。型変換した上での比較はしません。< / p >
2020-08-04 21:41:23 +09:00
< p > < code > is empty< / code > と< code > is not empty< / code > のルールは、文字列・配列・バッファの長さや、オブジェクトが持つプロパティの数をテストするために用いられます。どちらのルールも、テストされるプロパティが< code > boolean< / code > や< code > null< / code > 、< code > undefined< / code > の値を持つ場合、通過しません。< / p >
2019-02-08 09:26:11 +09:00
< h4 > メッセージ列の扱い< / h4 >
2018-02-11 20:59:01 +09:00
< p > switchノ ードは入力メッセージの列に関する情報を保持する< code > msg.parts< / code > をデフォルトでは変更しません。< / p >
2018-07-20 13:35:24 +09:00
< p > 「< b > メッセージ列の補正< / b > 」オプションを指定すると、マッチした各ルールに対して新しいメッセージ列を生成します。このモードでは、switchノ ードは新たなメッセージ列を送信する前に、入力メッセージ列全体を内部に蓄積します。< b > settings.js< / b > の< code > nodeMessageBufferMaxLength< / code > を設定すると、蓄積するメッセージ数を制限できます。< / p >
2018-02-11 20:59:01 +09:00
< / script >