全部產品
Search
文件中心

Resource Orchestration Service:Fn::If

更新時間:Jun 19, 2024

調用內建函式Fn::If,如果指定的條件計算為true,則返回一個值;如果指定的條件計算為false,則返回另一個值。

說明

在模板Resources和Outputs屬性值中支援Fn::If內建函式,您可以使用ALIYUN::NoValue偽參數作為傳回值來刪除相應的屬性。

函式宣告

  • JSON

    {
      "Fn::If": [
        "condition_name",
        "value_if_true",
        "value_if_false"
      ]
    }
  • YAML

    • 完整函數的文法。

      Fn::If:
        - condition_name
        - value_if_true
        - value_if_false
    • 縮寫形式。

      !If [condition_name, value_if_true, value_if_false]

參數資訊

  • condition_name:Conditions中條件對應的條件名稱。通過條件名稱引用條件。

  • value_if_true:當指定的條件計算為true時,返回此值。

  • value_if_false:當指定的條件計算為false時,返回此值。

使用樣本

根據輸入的參數,確定是否建立資料盤。

ROSTemplateFormatVersion: '2015-09-01'
Parameters:
  EnvType:
    Default: pre
    Type: String
Conditions:
  CreateDisk:
    !Equals
      - prod
      - !Ref EnvType
Resources:
  WebServer:
    Type: ALIYUN::ECS::Instance
    Properties:
      DiskMappings:
        !If
          - CreateDisk
          - - Category: cloud_efficiency
              DiskName: FirstDataDiskName
              Size: 40
            - Category: cloud_ssd
              DiskName: SecondDataDiskName
              Size: 40
          - !Ref ALIYUN::NoValue
{
  "ROSTemplateFormatVersion": "2015-09-01",
  "Parameters": {
    "EnvType": {
      "Default": "pre",
      "Type": "String"
    }
  },
  "Conditions": {
    "CreateDisk": {
      "Fn::Equals": [
        "prod",
        {
          "Ref": "EnvType"
        }
      ]
    }
  },
  "Resources": {
    "WebServer": {
      "Type": "ALIYUN::ECS::Instance",
      "Properties": {
        "DiskMappings": {
          "Fn::If": [
            "CreateDisk",
            [
              {
                "Category": "cloud_efficiency",
                "DiskName": "FirstDataDiskName",
                "Size": 40
              },
              {
                "Category": "cloud_ssd",
                "DiskName": "SecondDataDiskName",
                "Size": 40
              }
            ],
            {
              "Ref": "ALIYUN::NoValue"
            }
          ]
        }
      }
    }
  }
}

支援的函數