> ## Documentation Index
> Fetch the complete documentation index at: https://docs-dev-docs-ai-docs-migration-poc.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# 変数とヘルパー関数

> アクション用のフォームで変数を使用する方法を説明します。

変数を使用すると、フォームとフローに含まれるデータにアクセスして、カスタムビジネスロジックと自動化を作成できます。

変数を使用する際の基本的な考慮事項は次のとおりです。

* 変数は中括弧`{{ variable }}`で囲みます。
* 変数が存在しないか解決できない場合は、`未定義`の変数と同じ効果があります。
* `null`または`未定義`の変数を処理するには、nullish演算子を使用できます。例:`{{fields.foo ?? fields.bar}}`。

## 利用できる変数

フォームとフローを使用して顧客から収集したデータを参照および変換するには、さまざまな種類の変数を使用できます。

| 変数                              | 構文                | 場所       | 説明                             |
| ------------------------------- | ----------------- | -------- | ------------------------------ |
| Context（コンテキスト）                 | `{{context.*}}`   | フォーム/フロー | 現在のトランザクションのリファレンスコンテキストデータ    |
| Form fields（フォームフィールド）          | `{{fields.*}}`    | フォーム/フロー | フォームフィールドと非表示フィールドからのリファレンスデータ |
| Shared variables（共有変数）          | `{{vars.*}}`      | フォーム/フロー | 共有変数として保存されたリファレンスデータ          |
| Flow actions output（フローアクション出力） | `{{actions.*}}`   | フロー      | 前のフローアクションの出力応答からのリファレンスデータ    |
| Helper functions（ヘルパー関数）        | `{{functions.*}}` | フォーム/フロー | データ変換のためのヘルパー関数                |

### コンテキスト変数

フォームとフローは、現在のトランザクションからコンテキスト変数を自動的に継承します。次のコンテキスト変数にアクセスできます。

* `user`オブジェクト。以下に挙げたプロパティにアクセスできます。

  * `user.user_id`
  * `user.username`
  * `user.name`
  * `user.given_name`
  * `user.family_name`
  * `user.nickname`
  * `user.email`
  * `user.email_verified`
  * `user.phone_number`
  * `user.phone_verified`
  * `user.picture`
  * `user.user_metadata`
  * `user.app_metadata`
  * `user.created_at`
  * `user.updated_at`
  * `user.last_password_reset`
  * `user.identities`
* 次のプロパティにアクセスできる`組織`オブジェクト。

  * `organization.id`
  * `organization.name`
  * `organization.display_name`
  * `organization.metadata`
* 次のプロパティにアクセスできる`クライアント`オブジェクト。

  * `client.client_id`
  * `client.name`
* 次のプロパティにアクセスできる`テナント`オブジェクト。

  * `tenant.name`
* 次のプロパティにアクセスできる`トランザクション`オブジェクト。

  * `transaction.state`

<Accordion title="コンテキストオブジェクトの例">
  ```json lines expandable theme={null}
  {
    "user": {
      "user_id": "auth0|658409...",
      "name": "ana@travel0.com",
      "nickname": "ana",
      "email": "ana@travel0.com",
      "email_verified": true,
      "picture": "https://s.gravatar.com/avatar/8eb1b522f6...",
      "user_metadata": {},
      "app_metadata": {},
      "created_at": "2023-12-21T09:46:40.487Z",
      "updated_at": "2024-05-07T10:44:26.271Z",
      "last_password_reset": "2023-12-21T09:49:08.932Z",
      "identities": [
        {
          "user_id": "6584...",
          "isSocial": false,
          "provider": "auth0",
          "connection": "Username-Password-Authentication"
        }
      ]
    },
    "client": {
      "client_id": "xpeg5...",
      "name": "My App"
    },
    "tenant": {
      "name": "tenant-testing"
    },
    "transaction": {
      "state": "hKFo2SBId2M0..."
    }
  }
  ```
</Accordion>

例：  `{{context.user.user_id}}`は、`ユーザー`オブジェクトの`user_id`を参照します。

<Frame>
  <img src="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=e5ac3d9d73c29c86578c732347f6ecb7" alt="Dashboard > Forms > Flows" data-og-width="1141" width="1141" data-og-height="219" height="219" data-path="docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png" data-optimize="true" data-opv="3" srcset="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=280&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=da5a04d6d18bad4242cf4bbdcf8acbdd 280w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=560&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=e7b15ef2b7e6bcc3dee946608ef989f5 560w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=840&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=61d5d7a14edf0cb14c0a0e51c74ab709 840w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=1100&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=e3dcecbfae87ad234fd14ec12da4161e 1100w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=1650&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=a8fef13e6bb2f6933b2f1fa13792d1ee 1650w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=2500&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=67c5c7716ec392461913ab4308ada393 2500w" />
</Frame>

### フォームフィールド変数

フィールド変数には、フォームの入力フィールドからユーザーから収集されたデータと、非表示フィールドのデータが含まれます。各フィールドのデータは、フィールドタイプによって異なります。例：`{{fields.first_name`}}は、IDが`first_name`のフィールドの入力値を参照します。

<Frame>
  <img src="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=d84b39a773fa0fa17e9b53ba0da4f951" alt="Dashboard > Actions > Forms > Form" data-og-width="1404" width="1404" data-og-height="497" height="497" data-path="docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png" data-optimize="true" data-opv="3" srcset="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=280&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=d8f2838007fda86c12ff72b19fcaa5b7 280w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=560&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=0797fe3fcc8d9026df66d0950e00cfc3 560w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=840&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=92f05daaeb3b03c1030325598d45b27d 840w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=1100&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=90ee7b8a978ef846314c6a7fb531abcd 1100w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=1650&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=c98559cf23c58b4ec6aa5d8de6e3900d 1650w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=2500&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=300b1c4d95fb684bc575fe2efbae3e70 2500w" />
</Frame>

### フロー出力アクション変数

フローアクションが実行されると、後続のアクションで参照できる出力オブジェクト応答が生成されます。例：`{{actions.generate_otp.code}}`は、IDが`generate_otp`のアクションの出力コードを参照します。

<Frame>
  <img src="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/pbh9ApgKN42zSFup/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?fit=max&auto=format&n=pbh9ApgKN42zSFup&q=85&s=af38a7a0c19631987d6c1dd09796505d" alt="Dashboard > Actions > Forms > Flows" data-og-width="1404" width="1404" data-og-height="253" height="253" data-path="docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png" data-optimize="true" data-opv="3" srcset="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/pbh9ApgKN42zSFup/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=280&fit=max&auto=format&n=pbh9ApgKN42zSFup&q=85&s=7f539634b8acc3758d05fbcec2f52692 280w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/pbh9ApgKN42zSFup/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=560&fit=max&auto=format&n=pbh9ApgKN42zSFup&q=85&s=e12ecc17106754e240a7c078ce39d2ed 560w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/pbh9ApgKN42zSFup/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=840&fit=max&auto=format&n=pbh9ApgKN42zSFup&q=85&s=a9d5ec75ecd7714ededf9dc56f98ed6c 840w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/pbh9ApgKN42zSFup/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=1100&fit=max&auto=format&n=pbh9ApgKN42zSFup&q=85&s=172c0373f823be828665471234b87d01 1100w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/pbh9ApgKN42zSFup/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=1650&fit=max&auto=format&n=pbh9ApgKN42zSFup&q=85&s=bb22c6b77fb083d57a50383dc9b5bf37 1650w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/pbh9ApgKN42zSFup/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=2500&fit=max&auto=format&n=pbh9ApgKN42zSFup&q=85&s=6f6bef2c7fe625fe2a25c38e71ef7699 2500w" />
</Frame>

### 共有変数

後続のフローと共有する変数、または同じトランザクション内のフォームコンポーネントと共有する変数を保存できます。共有変数は一時的なものであり、特定のフォームジャーニーに関連付けられています。その値には、そのジャーニーの外部からはアクセスできません。例：`{{vars.external_id}}`は、IDが`external_id`の共有変数の値を参照します。

<Frame>
  <img src="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=027b5ed578ab42e052b3dfb431709066" alt="Dashboard > Actions > Forms > Flows" data-og-width="1215" width="1215" data-og-height="162" height="162" data-path="docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png" data-optimize="true" data-opv="3" srcset="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=280&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=d30542a3a70cdc3de239eef57ca031b5 280w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=560&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=c5c4cfacf9e86ebc96abc9a57739a880 560w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=840&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=233f8847b7eeeb47951b41327550a417 840w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=1100&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=cfa33bc18d13f029d15646fb076a9f94 1100w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=1650&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=ec9ab3a73284566af52d331cda41961f 1650w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/vef0um6ApqE_mEBO/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=2500&fit=max&auto=format&n=vef0um6ApqE_mEBO&q=85&s=4673c64bc0595bf03a828d38c4adb9b1 2500w" />
</Frame>

<Warning>
  共有変数は：

  * 内部（サーバー側）であり、ブラウザー（クライアント側）には公開されません。
  * フォームコンポーネントで共有変数を参照した場合、解決してブラウザーに公開できます。
</Warning>

### ヘルパー関数

ヘルパー関数を使用すると、データを変換して簡単な操作を実行できます。例：`{{functions.toString(fields.privacy_policies)}}`は、`toString()`関数を使用して、ID`privacy_policies`のフィールドの値を変換します。

<Frame>
  <img src="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/nuETm0IRwQM7ZTjR/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?fit=max&auto=format&n=nuETm0IRwQM7ZTjR&q=85&s=d78ab7168ec8083c38b2915e7b846850" alt="Dashboard > Actions > Forms > Flows" data-og-width="1404" width="1404" data-og-height="290" height="290" data-path="docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png" data-optimize="true" data-opv="3" srcset="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/nuETm0IRwQM7ZTjR/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=280&fit=max&auto=format&n=nuETm0IRwQM7ZTjR&q=85&s=1428c4c7571cebebae9ecdd9e451991b 280w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/nuETm0IRwQM7ZTjR/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=560&fit=max&auto=format&n=nuETm0IRwQM7ZTjR&q=85&s=ef220ba51afdc5bd83c317e26bcbd099 560w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/nuETm0IRwQM7ZTjR/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=840&fit=max&auto=format&n=nuETm0IRwQM7ZTjR&q=85&s=fb0cfed70474e82ec3beaa6770dcca0f 840w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/nuETm0IRwQM7ZTjR/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=1100&fit=max&auto=format&n=nuETm0IRwQM7ZTjR&q=85&s=11038eae9beec7d7c9f51a14a6d93cd6 1100w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/nuETm0IRwQM7ZTjR/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=1650&fit=max&auto=format&n=nuETm0IRwQM7ZTjR&q=85&s=d8aaf8e66be20446a64f50fe27f3d93b 1650w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/nuETm0IRwQM7ZTjR/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=2500&fit=max&auto=format&n=nuETm0IRwQM7ZTjR&q=85&s=c95fb7e624d6c56a41f69a8edd4bc45a 2500w" />
</Frame>

使用可能なヘルパー関数は次のとおりです。

| 関数                                     | 説明                                                                                                                                                                                                            | 例                                                                                                             |
| -------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- |
| toArray(value)                         | 値を配列に変換します                                                                                                                                                                                                    | `{{ functions.toArray('abc') }} // ['abc']`                                                                   |
| toBoolean(value)                       | 値をブール値に変換します                                                                                                                                                                                                  | `{{ functions.toBoolean(1) }} // true `<br /><br />`{{ functions.toBoolean(0) }} // false`                    |
| length(value)                          | パラメーター値の長さを返します                                                                                                                                                                                               | `{{ functions.length('auth0') }} // 5`                                                                        |
| mask(value)                            | 実行時に公開されないように値をマスクします                                                                                                                                                                                         | `{{ functions.mask('my_awesome_secret') }} // ███`                                                            |
| toNumber(value)                        | 値を数値に変換します                                                                                                                                                                                                    | `{{ functions.toNumber('123') }} // 123`                                                                      |
| random(min, max, \[boolean])           | 最小値と最大値の間の乱数を返します                                                                                                                                                                                             | `{{ functions.random(0, 6) }} // 4 `<br /><br />`{{ functions.random(0, 6, true) }} // 3.8523497...`          |
| slice(value, start, end)               | 開始インデックスと終了インデックスの間の値配列または文字列のセクションを返します                                                                                                                                                                      | `{{ functions.slice( 'example', 3, 5) }} // 'mp'`                                                             |
| toString(value)                        | 値を文字列に変換します                                                                                                                                                                                                   | `{{ functions.toString(123) }} // '123'`                                                                      |
| substring(value, start, end)           | 開始インデックスと終了インデックスの間の値のセクションを返します。[sliceとsubstring関数の違い](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/substring#differences_between_substring_and_slice)についてお読みください | `{{ functions.substring( 'example’', 3, 5) }} // 'mp'`                                                        |
| toTimestamp()                          | 現在のUNIXタイムスタンプを返します                                                                                                                                                                                           | `{{ functions.toTimestamp() }} // 1628761483`                                                                 |
| toTimestamp(date)                      | 指定された日付をUNIX時間で返します                                                                                                                                                                                           | `{{ functions.toTimestamp('2021-04-30T10:02:50.876Z') }} // 1619776970`                                       |
| toTimestamp(date)                      | 指定された日付をUNIX時間で返します                                                                                                                                                                                           | `{{ functions.toTimestamp('2021-04-30T10:02:50.876Z') }} // 1619776970`                                       |
| replaceAll(value, string, replacement) | パターンに一致するすべての部分を置換文字列に置き換えた新しい文字列を返します。                                                                                                                                                                       | `{{ functions.replaceall('2021-04-30', '-', '/') }} // 2021/04/30`                                            |
| replace(value, string, replacement)    | パターンに一致するすべての部分を置換文字列に置き換えた新しい文字列を返します。パターンが文字列の場合、最初の出現のみが置換されます。                                                                                                                                            | `{{ functions.replace('2021-04-30', '-', '/') }} // 2021/04-30`                                               |
| split(value, Separator, limit?)        | セパレーターで区切られた部分文字列の順序付きリストを返します。                                                                                                                                                                               | `{{ functions.split('2021-04-30', '-') }} // ['2021', '04', '30']`                                            |
| now()                                  | 現在の日付をISO8601形式で返します。                                                                                                                                                                                         | `{{ functions.now() }} // 2021-04-30T10:31:28.576Z`                                                           |
| includes(collection, item, fromIndex?) | 配列のエントリに特定の値が含まれているかどうかを返します。                                                                                                                                                                                 | `{{ functions.includes(['auth0', 'identity', 'authentication'], 'identity') }} // true`                       |
| indexOf(collection, item, fromIndex?)  | 配列内で特定の要素が見つかる最初のインデックスを返します。存在しない場合は-1を返します。                                                                                                                                                                 | `{{ functions.indexOf(['auth0', 'identity', 'authentication'], 'identity') }} // 1`                           |
| merge(base, value)                     | 基本データ型に応じて、結合された配列、オブジェクト、または連結された文字列を返します。                                                                                                                                                                   | `{{ functions.merge(['auth0', 'identity'], ['authentication']) }} // ['auth0', 'identity', 'authentication']` |
| md5(value)                             | MD5 ハッシュ値を返します。                                                                                                                                                                                               | `{{ functions.md5('auth0') }} // 7bbb597...`                                                                  |
| sha1(value)                            | SHA1 ハッシュ値を返します。                                                                                                                                                                                              | `{{ functions.sha1('auth0') }} // b4ec5339...`                                                                |
| sha256(value)                          | SHA256ハッシュ値を返します。                                                                                                                                                                                             | `{{ functions.sha256('auth0') }} // d9082bdc...`                                                              |
| sha512(value)                          | SHA512ハッシュ値を返します。                                                                                                                                                                                             | `{{ functions.sha512('auth0') }} // c0d588069d...`                                                            |
| uuid()                                 | ランダムなv4 UUIDを返します                                                                                                                                                                                             | `{{ functions.uuid() }} // 36b8f84d-df4e-4d49-b662-bcde71a8764`                                               |

## 変数のベストプラクティス

### 意味のあるIDを使用する

フォームフィールドまたはフローアクションを追加すると、IDが自動的に生成されます。

IDをよりわかりやすい値に更新して、含まれる情報を識別できるようにします。たとえば、ユーザーの名を保存するフォームフィールドを作成する場合は、IDを`first_name`に更新します。

### 既存のIDを更新するときは注意してください

変数がすでに使用されており、IDを変更する必要がある場合は、参照した場所を特定し、それに応じてIDを更新して、未定義または空の値にならないようにします。

### フロー実行を確認する

予期しない変数値が表示された場合は、[**実行** ](/docs/ja-jp/customize/forms/flows/flow-execution-and-debugger)ビューを使用して変数のトラブルシューティングを行います。

### オートコンプリートメニューを使用する

オートコンプリートメニューを使用すると、既存の変数を見つけて適切に参照できます。

<Frame>
  <img src="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=0e91fa52ca25de4d49f71e98a57e699b" alt="Dashboard > Actions > Forms > Flows" data-og-width="1361" width="1361" data-og-height="502" height="502" data-path="docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png" data-optimize="true" data-opv="3" srcset="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=280&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=1607572d466cb72b6dadc803c57bc183 280w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=560&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=cd4f0782c94f9e67b4cb4496b04e246b 560w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=840&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=6d005a97f915929e894e672f4da9dfa7 840w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=1100&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=8455785d1a54a7dbfa7b145ee0b888a3 1100w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=1650&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=12a88b24028bd747985649550d8f57df 1650w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=2500&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=fa5580b216d9bcd9720a26bde953202c 2500w" />
</Frame>

<Frame>
  <img src="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=67736feecd0c4b4977f01fcef59fab7d" alt="Dashboard > Actions > Forms > Form" data-og-width="1394" width="1394" data-og-height="630" height="630" data-path="docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png" data-optimize="true" data-opv="3" srcset="https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=280&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=fa77bc893f4ee1b31082e5d9fa156b9b 280w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=560&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=6b032b065f588cc6ba8e3eab5604ba9e 560w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=840&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=d6eebc9df47157413f27ae9b67190c0f 840w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=1100&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=8b6b988de3f0357b6b5c48202e035d76 1100w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=1650&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=7e129a73fe0ef52eeee406189e509598 1650w, https://mintcdn.com/docs-dev-docs-ai-docs-migration-poc/gOjxgRCfcCXHpbhL/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=2500&fit=max&auto=format&n=gOjxgRCfcCXHpbhL&q=85&s=32a1c67c77e4bf8c610e2bcd0112ba2a 2500w" />
</Frame>
