Challenge programming

Vue.js

複数チェックボックスでの双方向データバインド | Bidirectional data binding with checkboxes and radio buttons in Vue.js

ご注文をお選びください:{{selection}}
    

1つ1つのチェックボックスに別々のプロパティをバインドするのではなく、グループに対して1つのプロパティをバインドする。

バインドさせるデーターは配列なので、あらかじめ空の配列[]を宣言しておく。

また、文字列に変換する変換するプロパティを用意しておくと便利。ここではjoin()関数を使用してます。

HTML <div id="app">
<span class="yellow">ご注文をお選びください:{{selection}}</span>
<label>
<input type="checkbox" v-model="answer" value="ケーキ">ケーキ
</label>
<label>
<input type="checkbox" v-model="answer" value="紅茶">紅茶
</label>
<label>
<input type="checkbox" v-model="answer" value="コーヒー">コーヒー
</label>
</div>
CSS .yellow {
background: linear-gradient(transparent 65%, yellow 65%);
}
   
JavaScript var app = new Vue({
el: '#app',
data: {
answer:[]
},
computed: {
// チェック内容を連結した文字列を返す算出プロパティ
selection: function(){
return this.answer.join();
}
}
});

ラジオボタンにバインドする

当店のサービスはいかがでしたか?:{{answer2}}

ラジオボタンはグループ内で常に1つしか選択できないので、バインドしたプロパティは配列ではなく文字列となります。

HTML <div id="app2">
<p>当店のサービスはいかがでしたか?:{{answer2}}</p>
<label>
<input type="radio" v-model="answer2" value="素晴らしい">素晴らしい
</label>
<label>
<input type="radio" v-model="answer2" value="普通">普通
</label>
<label>
<input type="radio" v-model="answer2" value="まだまだ">まだまだ
</label>
</div>
CSS .red {
color: red;
}
   
JavaScript var app2 = new Vue({
el: '#app2',
data: {
answer2: '選択してください'
}
});

この本を参考に学び、完成させることができました。しかし、プログラミング初心者の私が詳しく解説することは、おこがましく、難しく出来ません(ToT) その点、この本では丁寧な解説が載っていますので、解説とともにコードを書き、完成させればより深く学ぶことができます(^.^) 身に付けて消えないスキルがこの値段。買っておいてよかったです。

やっぱりプロの人から直接学びたいという方はこちら。| Click here if you want to learn directly from professionals

キャリアアップに必要なスキルを取得しよう。| Get the skills you need to advance your career.

オンラインで受講ができるスクールですので、全国どこからでも。 | Since it is a school where you can take classes online, you can take it from anywhere in the country.

ぺージの先頭に戻る(Return to top of page)


©2020年9月 Challenge programming

プライバシーポリシー