1
0
mirror of https://github.com/node-red/node-red.git synced 2023-10-10 13:36:53 +02:00
2019-03-20 18:27:04 +09:00

139 lines
9.6 KiB
HTML

<!--
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.
-->
<script type="text/x-red" data-help-name="split">
<p>메세지를 메세지열로 분할합니다.</p>
<h3>입력</h3>
<dl class="message-properties">
<dt>payload<span class="property-type">오브젝트 | 문자열 | 배열 | 버퍼</span></dt>
<dd><code>msg.payload</code> .
<ul>
<li><b>문자열</b>/<b>버퍼</b> - (: <code>\n</code>), , .</li>
<li><b>배열</b> - .</li>
<li><b>오브젝트</b> - / .</li>
</ul>
</dd>
</dl>
<h3>출력</h3>
<dl class="message-properties">
<dt>parts<span class="property-type">오브젝트</span></dt>
<dd>원래 메세지를 어떻게 분할했는지에 관한 정보를 프로퍼티에 유지합니다. 예를 들면, <b>join</b> , . <code>parts</code> .
<ul>
<li><code>id</code> - </li>
<li><code>index</code> - </li>
<li><code>count</code> - , . '' </li>
<li><code>type</code> - - ///</li>
<li><code>ch</code> - , </li>
<li><code>key</code> - , .
노드의 설정에 의해 키를 <code>msg.topic</code> .</li>
<li><code>len</code> - .</li>
</ul>
</dd>
</dl>
<h3>상세</h3>
<p> 노드는, 메세지열을 구성하는 메세지에 대해 공통 처리를 수행하고, <b>join</b> .</p>
<p><code>msg.parts</code> .</p>
<h4>스트림모드</h4>
<p> 노드는 메세지열을 재구성하여 송신할 때에도 유용합니다. 예를 들면, 바꿈 마지막의 커맨드를 송신하는 시리얼 디바이스에서는, 메세지의 마지막 커맨드부분이 끊어진 메세지를 송출하는 경우가 있습니다. '스트림모드' 사용하여, 완결된 개별 커맨드에 메세지를 분할할 있습니다. 입력메세지 마지막에 미완성 부분이 있는 경우, <b>split</b> , .</p>
<p> 모드에서 처리할 때에는, 메세지 수를 미리 없기 때문에, <code>msg.parts.count</code> . , <b>join</b> '' .</p>
</script>
<script type="text/x-red" data-help-name="join">
<p>메세지열를 결합하여 하나의 메세지로 만듭니다.</p>
<p>메세지의 결합에는 다음 3개의 모드를 이용할 있습니다.</p>
<dl>
<dt>자동</dt>
<dd><b>split</b> , split .</dd>
<dt>수동</dt>
<dd>메세지열을 다양한 방법으로 결합합니다.</dd>
<dt>열의 집약</dt>
<dd>메세지열에 대해 지정한 식을 적용하여, 하나의 메세지로 집약합니다.</dd>
</dl>
<h3>입력</h3>
<dl class="message-properties">
<dt class="optional">parts<span class="property-type">오브젝트</span></dt>
<dd>자동적으로 메세지열을 결합하기 위해서는, 모든 메세지가 프로퍼티를 갖고 있어야합니다. <b>split</b> , . <code>parts</code> .
<ul>
<li><code>id</code> - </li>
<li><code>index</code> - </li>
<li><code>count</code> - </li>
<li><code>type</code> - - string/array/object/buffer</li>
<li><code>ch</code> - , </li>
<li><code>key</code> - , </li>
<li><code>len</code> - </li>
</ul>
</dd>
<dt class="optional">complete</dt>
<dd>설정되어 있는 경우, 유지하고 있는 메세지를 결합하여 송신합니다.</dd>
</dl>
<h3>상세</h3>
<h4>자동모드</h4>
<p>자동모드에서는, 입력메세지의 <code>parts</code> . <b>split</b> .</p>
<h4>수동모드</h4>
<p>수동모드에서는, 메세지열을 다양한 결과로 결합할 있습니다.</p>
<ul>
<li><b>문자열</b> <b></b> - </li>
<li><b>배열</b> - </li>
<li><b>key/value오브젝트</b> - , </li>
<li><b>통합오브젝트</b> - </li>
</ul>
<p>출력메세지의 외의 프로퍼티는 메세지를 송신하기 직전의 메세지를 복사합니다.</p>
<p>'<i>합계값</i>'에는 출력메세지를 송신하기 전에 수신해야 메세지 수를 지정합니다. 오브젝트 출력인 경우, 합계값에 달하면 후속 메세지가 도착할 마다 메세지를 출력하도록 설정할 수도 있습니다.</p>
<p>'<i>초</i>'에는 신규 메세지를 송신하기 까지의 경과시간을설정합니다.</p>
<p><code>msg.complete</code> , . , .</p>
<p><code>msg.reset</code> , . . , .</p>
<h4>열의 집약모드</h4>
<p>열의 집약모드를 선택하면, 메세지열을 구성하는 각각의 메세지에 대해 식을 적용햐여, 집약한 값을 이용하여 하나의 메세지를 구성합니다.</p>
<dl class="message-properties">
<dt>초기값</dt>
<dd>
집약의 초기값(<code>$A</code>)
</dd>
<dt>집약식</dt>
<dd>메세지그룹을 구성하는 메세지에 적용되는 JSONata식.
식의 평가결과는 다음 호출때에 집약값으로 전달합니다.
<ul>
<li><code>$A</code> </li>
<li><code>$I</code> </li>
<li><code>$N</code> </li>
</ul>
</dd>
<dt>최종조정식</dt>
<dd>메세지그룹의 집약이 완료된 후에 적용되는 JSONata식. 임의로 지정가능 합니다. 식에는 아래의 특수변수를 참조할 있습니다.
<ul>
<li><code>$A</code> </li>
<li><code>$N</code> </li>
</ul>
</dd>
<p>메세지그룹의 메세지에 대해, 기본값으로는 집약식은 처음 메세지로 부터 마지막 메세지에 대해 순서대로 적용됩니다. 적용을 역순으로 하는 것도 가능합니다.</p>
</dl>
<p><b>:</b> , .
<ul>
<li><b>집약식</b>: <code>$A+payload</code></li>
<li><b>초기값</b>: <code>0</code></li>
<li><b>최종조정식</b>: <code>$A/$N</code></li>
</ul>
</p>
<h4>메세지의 축적</h4>
<p> 노드의 처리에서는 메세지열의 처리를 위해 메세지를 내부에 축적합니다. <code>nodeMessageBufferMaxLength</code> .</p>
</script>