element-plus/website/docs/jp/switch.md
三咲智子 55348b30b6
style: use prettier (#3228)
* style: use prettier

* style: just prettier format, no code changes

* style: eslint fix
object-shorthand, prefer-const

* style: fix no-void

* style: no-console
2021-09-04 19:29:28 +08:00

8.1 KiB

スイッチ

スイッチは、2 つの状態を切り替えるために使用されます。

基本的な使い方

:::demo v-modelBoolean 型変数にバインドする。active-colorinactive-color属性は、2 つの状態の背景色を決定する。

<el-switch v-model="value1"> </el-switch>
<el-switch v-model="value2" active-color="#13ce66" inactive-color="#ff4949">
</el-switch>

<script>
  export default {
    data() {
      return {
        value1: true,
        value2: true,
      }
    },
  }
</script>

:::

テキストの説明

:::demo テキストを表示するために active-colorinactive-color 属性を追加することができます。

<el-switch
  v-model="value1"
  active-text="Pay by month"
  inactive-text="Pay by year"
>
</el-switch>
<el-switch
  style="display: block"
  v-model="value2"
  active-color="#13ce66"
  inactive-color="#ff4949"
  active-text="Pay by month"
  inactive-text="Pay by year"
>
</el-switch>

<script>
  export default {
    data() {
      return {
        value1: true,
        value2: true,
      }
    },
  }
</script>

:::

拡張された値型

:::demo active-valueinactive-valueを設定することができる。どちらも Boolean, String または Number 型の値を受け取る。

<el-tooltip :content="'Switch value: ' + value" placement="top">
  <el-switch
    v-model="value"
    active-color="#13ce66"
    inactive-color="#ff4949"
    active-value="100"
    inactive-value="0"
  >
  </el-switch>
</el-tooltip>

<script>
  export default {
    data() {
      return {
        value: '100',
      }
    },
  }
</script>

:::

無効化

:::demo disabled属性を追加すると、スイッチを無効にすることができます。

<el-switch v-model="value1" disabled> </el-switch>
<el-switch v-model="value2" disabled> </el-switch>

<script>
  export default {
    data() {
      return {
        value1: true,
        value2: false,
      }
    },
  }
</script>

:::

ローディング

:::demo loading属性をtrueに設定すると、ロード状態を表示することができます。

<el-switch v-model="value1" loading> </el-switch>
<el-switch v-model="value2" loading> </el-switch>
<script>
  export default {
    data() {
      return {
        value1: true,
        value2: false,
      }
    },
  }
</script>

:::

切り替えを防ぐ

:::demo beforeChangeプロパティを設定します。false を返すか、Promise を返し、拒否された場合は、切り替えを停止します。

<el-switch v-model="value1" :loading="loading1" :beforeChange="beforeChange1">
</el-switch>
<el-switch v-model="value2" :loading="loading2" :beforeChange="beforeChange2">
</el-switch>
<script>
  import { reactive, toRefs } from 'vue'
  import { ElMessage } from 'element-plus'

  export default {
    setup() {
      const status1 = reactive({
        value1: false,
        loading1: false,
      })

      const beforeChange1 = () => {
        status1.loading1 = true
        return new Promise((resolve) => {
          setTimeout(() => {
            status1.loading1 = false
            ElMessage.success('正常に切り替えます')
            return resolve(true)
          }, 1000)
        })
      }

      const status2 = reactive({
        value2: false,
        loading2: false,
      })

      const beforeChange2 = () => {
        status2.loading2 = true
        return new Promise((resolve, reject) => {
          setTimeout(() => {
            status2.loading2 = false
            ElMessage.error('スイッチに失敗しました')
            return reject(new Error('error'))
          }, 1000)
        })
      }

      return {
        ...toRefs(status1),
        ...toRefs(status2),
        beforeChange1,
        beforeChange2,
      }
    },
  }
</script>

:::

属性

Attribute Description Type Accepted Values Default
model-value / v-model バインド値は、"active-value "または "inactive-value "と等しくなければなりません。デフォルトの型は "boolean "です。 boolean / string / number
disabled スイッチが無効になっているかどうか boolean false
loading スイッチがロード中になっているかどうか boolean false
width スイッチの幅 number 40
active-icon-class on 状態のときに表示されるアイコンのクラス名で、active-text を上書きします。 string
inactive-icon-class off 状態のときに表示されるアイコンのクラス名で、inactive-text を上書きします。 string
active-text on 状態のときに表示されるテキスト string
inactive-text off 状態のときに表示されるテキスト string
active-value on 状態のときのスイッチの値 boolean / string / number true
inactive-value off 状態のときのスイッチの値 boolean / string / number false
active-color on 状態のときの背景色 string #409EFF
inactive-color off 状態のときの背景色 string #C0CCDA
border-color スイッチの境界線の色 string
name スイッチのインプット名 string
validate-event フォームバリデーションをトリガするかどうか boolean true
before-change スイッチの状態が変化する前のフックは、false を返すか、Promise を返し、切り替えを停止するために拒否されます function

イベント

Event Name Description Parameters
change 値が変わるとトリガー value after changing

メソッド

Method Description Parameters
focus スイッチコンポーネントにフォーカス