目次

Vue.js 3.x TwoInputsForm コンポーネント

要求

コード

TwoInputsForm.js
import { computed } from 'https://cdnjs.cloudflare.com/ajax/libs/vue/3.0.11/vue.esm-browser.js';
import { getWrapClass } from 'https://wws.jp/_export/code/vuejs/vue3/form_utils?codeblock=0';
 
const TwoInputsForm = {
  template: `
    <div :class="computedFirstControlWrapperClasses" :style="controlWrapperStyles">
      <input class="form-control" :type="type"
        :class="controlClasses"
        :style="controlStyles"
        :value="firstValue"
        v-bind="$attrs"
        @input="$emit('update:firstValue', $event.target.value)"
      >
      <div :class="computedFirstMessageWrapperClasses" :style="messageWrapperStyles">
        <template v-for="msg in firstErrors">
          <span>{{ msg }}</span><br>
        </template>
      </div>
    </div>
    <div :class="computedSecondControlWrapperClasses" :style="controlWrapperStyles">
      <input class="form-control" :type="type"
        :class="controlClasses"
        :style="controlStyles"
        :value="secondValue"
        v-bind="$attrs"
        @input="$emit('update:secondValue', $event.target.value)"
      >
      <div :class="computedSecondMessageWrapperClasses" :style="messageWrapperStyles">
        <template v-for="msg in secondErrors">
          <span>{{ msg }}</span><br>
        </template>
      </div>
    </div>
  `,
  props: {
    type:                  { type: String, default: 'text' },
    firstValue:            { type: String, default: '' },
    secondValue:           { type: String, default: '' },
    firstErrors:           { type: Array,  default: [] },
    secondErrors:          { type: Array,  default: [] },
    controlWrapperClasses: { type: Array,  default: [] },
    controlWrapperStyles:  { type: Object, default: {} },
    controlClasses:        { type: Array,  default: [] },
    controlStyles:         { type: Object, default: {} },
    messageWrapperClasses: { type: Array,  default: [] },
    messageWrapperStyles:  { type: Object, default: {} },
    controlErrorClass:     { type: String, default: 'has-error' },
    messageErrorClass:     { type: String, default: 'text-danger' },
  },
  emits: ['update:firstValue', 'update:lastValue'],
  setup(props, context) {
    const computedFirstControlWrapperClasses = computed(() => {
      return getWrapClass(
        props.firstErrors,
        props.controlWrapperClasses,
        props.controlErrorClass
      )
    })
    const computedSecondControlWrapperClasses = computed(() => {
      return getWrapClass(
        props.secondErrors,
        props.controlWrapperClasses,
        props.controlErrorClass
      )
    })
    const computedFirstMessageWrapperClasses = computed(() => {
      return getWrapClass(
        props.firstErrors,
        props.messageWrapperClasses,
        props.messageErrorClass
      )
    })
    const computedSecondMessageWrapperClasses = computed(() => {
      return getWrapClass(
        props.secondErrors,
        props.messageWrapperClasses,
        props.messageErrorClass
      )
    })
    return {
      computedFirstControlWrapperClasses,
      computedFirstMessageWrapperClasses,
      computedSecondControlWrapperClasses,
      computedSecondMessageWrapperClasses
    }
  }
};
export default TwoInputsForm;

Props

Property Type Default Description
firstValue String
secondValue String
controlWrapperClasses Array [] select を囲う div タグに反映するクラス
controlWrapperStyles Object {} select を囲う div タグに反映するスタイル
controlClasses Array [] 入力コントロールに反映するクラス
controlStyles Object {} 入力コントロールに反映するスタイル
messageWrapperClasses Array [] エラーメッセージを囲う div タグに反映するクラス
firstErrors Array [] エラーメッセージの配列
secondErrors Array [] エラーメッセージの配列
controlErrorClass String 'has-error' コントロールに反映するエラークラス
messageErrorClass String 'text-danger' エラーメッセージに反映するエラークラス

※ ここで記述されていない number や date, time などに指定可能なプロパティ min, max, step などは $attrs で input タグに自動的にバインドする.

Events

Event Value
update:value 選択された値

Demo