> ## Documentation Index
> Fetch the complete documentation index at: https://docs-staging-feat-update-styling-docs-for-universal-compone.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-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=745b63170043a8b234c60d54e55e60aa" 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-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=280&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=5c9b8bcb3d9160b7ee9ba6e763974e0e 280w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=560&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=ca742bad201802e8e817ae526784d62e 560w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=840&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=c1a352d8b4dce13fc567744a6b1cafc5 840w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=1100&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=bb2abc30467a625330cac8aa17be5c25 1100w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=1650&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=ea45f691f941d1c4e84fdbc0de1c88ec 1650w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3B8DRhXO2wGqeqSFb8KbQv/0a61cdbbb7f1d290950a2ddb9857aac3/Contex-variable.png?w=2500&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=731ff320184da8892b49ff211a8f34b2 2500w" />
</Frame>

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

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

<Frame>
  <img src="https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=459c7900d7c9f326214c6be1196e9649" 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-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=280&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=a33ff6818d08e95eb8acb3728c1dbc15 280w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=560&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=f8fe8d6a8d5fd671a3ebc44a2890981c 560w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=840&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=aa79de5c9d6604149100f19ba1a50ae2 840w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=1100&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=0b9b224580b9b366acda80155ce1464f 1100w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=1650&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=a3d27e8c90fc94b614fb457b426fdb6e 1650w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4D42A6ww4XvFxweoxh04Rd/016c2ed9d25bc2267ed3ed31bf8b2bf6/form-fields-variable.png?w=2500&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=ce4c219ee2e72d77f7cb39a8539f74cf 2500w" />
</Frame>

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

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

<Frame>
  <img src="https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/6qDGWk73oBOwKMaM/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?fit=max&auto=format&n=6qDGWk73oBOwKMaM&q=85&s=9ce37cd8f6aa45ebea58f74c63f4a81f" 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-staging-feat-update-styling-docs-for-universal-compone/6qDGWk73oBOwKMaM/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=280&fit=max&auto=format&n=6qDGWk73oBOwKMaM&q=85&s=bcc586d4492725d50c3d3d22b2f57c74 280w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/6qDGWk73oBOwKMaM/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=560&fit=max&auto=format&n=6qDGWk73oBOwKMaM&q=85&s=54862139d06eb9b648c0e26b18132d51 560w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/6qDGWk73oBOwKMaM/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=840&fit=max&auto=format&n=6qDGWk73oBOwKMaM&q=85&s=f5bed2dd71e5b40b85fae03f62d1ae3a 840w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/6qDGWk73oBOwKMaM/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=1100&fit=max&auto=format&n=6qDGWk73oBOwKMaM&q=85&s=5f1f1e2f846a9758d637dbdf6fac2da6 1100w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/6qDGWk73oBOwKMaM/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=1650&fit=max&auto=format&n=6qDGWk73oBOwKMaM&q=85&s=2c0c64a841e51b8f6a75459cc89f83f0 1650w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/6qDGWk73oBOwKMaM/docs/images/ja-jp/cdy7uua7fh8z/6jYtEdYqSGXm3DDv0mxQ0o/2d48012629745e07137bf6ba42f4d829/flow-output-variable.png?w=2500&fit=max&auto=format&n=6qDGWk73oBOwKMaM&q=85&s=d27070f0b1b071068289de857e7454df 2500w" />
</Frame>

### 共有変数

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

<Frame>
  <img src="https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=f654b14b8ed173b1a88c8da6b97b9e58" 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-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=280&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=3faf0b3775692c392c0891559d455c1d 280w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=560&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=413a63237ec4a3cddff47f2b5b2f25bf 560w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=840&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=108c6127267b277244c01df63030b0d1 840w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=1100&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=10098013ba1f32e605b09820df07687b 1100w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=1650&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=b7daf0318d7ba98fdba8b958fdd3ad0c 1650w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/tw2DXsNKLM5RFChR/docs/images/ja-jp/cdy7uua7fh8z/4571ExRTHL0KZKJKX9pNwj/abb631b8608a6356b0e5b3784cf8b02f/flow-shared-variable.png?w=2500&fit=max&auto=format&n=tw2DXsNKLM5RFChR&q=85&s=1b4f5499214df8c016cb12a346c8bdc1 2500w" />
</Frame>

<Warning>
  共有変数は：

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

### ヘルパー関数

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

<Frame>
  <img src="https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/si5AkofKSnvqe8Su/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?fit=max&auto=format&n=si5AkofKSnvqe8Su&q=85&s=7f2203707a61f8757f3370ce04d83a3d" 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-staging-feat-update-styling-docs-for-universal-compone/si5AkofKSnvqe8Su/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=280&fit=max&auto=format&n=si5AkofKSnvqe8Su&q=85&s=0c3a3a89ef54c12d972793f6dc34efff 280w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/si5AkofKSnvqe8Su/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=560&fit=max&auto=format&n=si5AkofKSnvqe8Su&q=85&s=dfbe183b632a840aa11c54b007b6de47 560w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/si5AkofKSnvqe8Su/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=840&fit=max&auto=format&n=si5AkofKSnvqe8Su&q=85&s=007bcb87892f984ec87be159be932c01 840w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/si5AkofKSnvqe8Su/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=1100&fit=max&auto=format&n=si5AkofKSnvqe8Su&q=85&s=308b826cd252494c83cb3db04bb792bf 1100w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/si5AkofKSnvqe8Su/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=1650&fit=max&auto=format&n=si5AkofKSnvqe8Su&q=85&s=7f92a9ff36ac55b3ddef9896e9e0a67b 1650w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/si5AkofKSnvqe8Su/docs/images/ja-jp/cdy7uua7fh8z/1gyox33XJEtdkT43NppblT/0e878cc5ae2bde11b4207e105bbac6c5/flow-helper-functions.png?w=2500&fit=max&auto=format&n=si5AkofKSnvqe8Su&q=85&s=be52f910d4e450d668677cf32663f998 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-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=343c42b608772b43dd7cb2b599749ef3" 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-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=280&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=4dc23203a63966b14541544396546c8c 280w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=560&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=b04114b0d5da3c28c599c2c162b95e13 560w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=840&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=0e4e7ff6e3687c62974feda6e7c19651 840w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=1100&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=eba9ddb8d82e5e235671eaf0c1e09a5d 1100w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=1650&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=71f797e879bec99b31e9a98e54309c93 1650w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/3SKnDuaMzSImxZtDDAoZaz/9ea800fad29ef71d1ded3c72b87660a4/Autocomplete-flows.png?w=2500&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=aec2dba13088e9044ee3716a36cb7af1 2500w" />
</Frame>

<Frame>
  <img src="https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=729c6685a42e0ab7e086f769ea554ca0" 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-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=280&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=aeb31665e438536c7fee781515909053 280w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=560&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=a6feff608657040df70d5d27b857c0c6 560w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=840&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=a6ff57b901e818db1478ebaf78b60df4 840w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=1100&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=59f64ef114fce85d78d89be8c2485902 1100w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=1650&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=99008d5fe2ff874c9e9823a622258dbb 1650w, https://mintcdn.com/docs-staging-feat-update-styling-docs-for-universal-compone/u2lg-cK6RhjIkYnn/docs/images/ja-jp/cdy7uua7fh8z/2kjRKozVgrd2a7UJXOANaN/ee5452d7210cd2f13b0e97763f11c82a/Autocomplete-forms.png?w=2500&fit=max&auto=format&n=u2lg-cK6RhjIkYnn&q=85&s=a1b62c6c765d0c22435ac76c54304951 2500w" />
</Frame>
