====== Vue.js 3.x LabeledInputForm コンポーネント ======
===== 要求 =====
* input の以下のタイプを実装するラベル付きコンポーネント
* text
* password
* email
* url
* number
* date
* time
* v-model 対応
* 再利用可能なコンポーネントとする。
* 指定可能な属性が異なるため、$attr をバインドするが、対応できない場合は別のコンポーネントとしてで作成する。
===== コード =====
import LabeledForm from '/_export/code/vuejs/vue3/labeled_form?codeblock=0';
import InputForm from '/_export/code/vuejs/vue3/input_form?codeblock=0';
const LabeledInputForm = {
template: `
===== Props =====
==== type ====
* type: String
* default: 'text
==== value ====
* type: String
==== errors ====
* type: Array
* default: []
==== labelText ====
* type: String
==== formWrapperClasses ====
* type: Array
* default: []
==== formWrapperStyles ====
* type: Object
* default: {}
==== labelWrapperClasses ====
* type: Array
* default: []
==== labelWrapperStyles ====
* type: Object
* default: { paddingTop: '7px' }
==== 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'
==== formErrorClass ====
* type: String
* default: 'has-error'
==== labelErrorClass ====
* type: String
* default: 'text-danger'
===== Events =====
===== Demo =====
==== テーブルライクなレイアウト ====