タイトルが長くなりましたが、前々からVue.jsのチェックボックスでハマることが多かったのでメモです。

環境


Vue.js 2.5.2

やりたいこと


下記のような感じにしたい。

  • 複数のチェックボックス
  • チェック・アンチェックで他のチェックボックスに影響を及ぼさないこと
  • チェック・アンチェックの見た目が反転しない
    • どうもブラウザごとに挙動が違う
    • チェックついてないのに内部的にtrueになる場合がある。逆も然り。
    • @clickとかv-modelとかv-bind:valueだとダメだった

んで、できれば初期値はAPIから取得してチェック・アンチェックでAPIにPATCH投げるような感じがいいですね。というわけで、続けて実装です。

実装


以下、雑な実装です。なお、動くかどうか試してないのでたぶんコピペだと動かないと思います。

まず、HTMLは下記のような感じにします。ここは前述のとおり@clickとかv-modelとかv-bind:valueとかを組み合わせて試したのですが、思うように動いたのは@changev-bind:checkedの組み合わせでした。

1
2
3
4
5
<div id="example">
<input type="checkbox" @change="toggleCheckBox1()" v-bind:checked="checkBoxExample.checkbox1">テスト1</input>
<input type="checkbox" @change="toggleCheckBox2()" v-bind:checked="checkBoxExample.checkbox2">テスト2</input>
<input type="checkbox" @change="toggleCheckBox3()" v-bind:checked="checkBoxExample.checkbox3">テスト3</input>
</div>

次にJS側です。このチェックボックス群はビジネスロジック的に一つのかたまりなのでクラスで状態管理とか、その他ごにょごにょします。後は特筆することはないですね。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
// チェックボックスの状態管理とか更新するためのクラス
class CheckBoxExample {
constructor(_checkbox1, _checkbox2, _checkbox3) {
this.checkbox1 = _checkbox1;
this.checkbox2 = _checkbox2;
this.checkbox3 = _checkbox3;
}

toggleCheckBox1() {
this.checkbox1 = !this.checkbox1
// なんかの処理...API叩くとか
}

toggleCheckBox2() {
this.checkbox2 = !this.checkbox2
// なんかの処理...API叩くとか
}

toggleCheckBox3() {
this.checkbox3 = !this.checkbox3
// なんかの処理...API叩くとか
}

}

const app = new Vue({
el: "example",
data: {
checkBoxExample = null;
},
created: function() {
let checkBoxStates = null;
// Vue.jsのインスタンス生成時にAPIでデータ取ってきて初期値設定みたいな
fetch('/api/checkboxstate')
.then((response) => {
checkBoxStates = JSON.parse(response); //たぶんこの辺動かないんじゃないかと思う
}
this.checkBoxExample = new CheckBoxExample(
checkBoxStates.checkbox1,
checkBoxStates.checkbox2,
checkBoxStates.checkbox3
);
},
methods: {
toggleCheckBox1() {
this.checkBoxExample.toggleCheckBox1();
},
toggleCheckBox2() {
this.checkBoxExample.toggleCheckBox2();
},
toggleCheckBox3() {
this.checkBoxExample.toggleCheckBox3();
}
}
});

適当な記事になってしまいましたが、個人向けメモなので勘弁して下さい。

その他


なんかVue.jsのいろんなサンプルとか見てもみんなdataに配列とかでベタベタ書いてるんですけど、それ普通なんすか??クラス使いたくない??使いたくないの??