Vue.jsのv-forで生成した要素をクリックするたびに、classをトグルで付け外しする方法

Vue.jsのv-forで複数の要素を生成した要素に、クリックするたびにclassをトグルで付け外しするためにはどうすればいいのでしょうか?
- classが付くのは常に1つの要素のみ
- すでに要素にclassが付いている状態で、別の要素をクリックした場合は、クリックした要素にclassが付く(それ以外の要素からはclassは外れる)
jQueryの場合はremoveClassですべての要素からclassを外して$(this)にaddClassするだけで済むのですが、Vue.jsの場合は少し工夫が必要です。
考えればすぐに分かりましたが、調べみても出てこなかったので備忘録として残しておきます。
v-forで生成した要素にトグルでclassを付け外しする
実装の考え方は下記の通りです。
v-forでループするときに使ったnを利用して、クリックしたときにactiveItemがnになるようにするactiveItemがnになったときにclass(今回の場合は.is-active)が付くようにする- すでに
activeItemがnになっているときは、nをnullにする(classが外れる)
See the Pen Vue.js toggle item by Masakazu Saito (@31mskz10) on CodePen.
コピー用のコードは下記になります。
<ul>
<li v-on:click="onActive(n)" v-for="n of 6" :key="n" v-bind:class="{ 'is-active': activeItem === n }">Item {{n}}</li>
</ul>(function() {
'use strict';
var vm = new Vue({
el: 'ul',
data() {
return {
activeItem: null
}
},
methods: {
onActive(n) {
if(this.activeItem === n){
this.activeItem = null;
}else{
this.activeItem = n;
}
}
}
});
})();要素が複数なので今回はnを使いましたが、1つの場合はtrue / falseで状態のチェックをしてあげれば作成できます。



Vue.jsで値段を表示するときに3桁ごとにカンマを入れる方法
Nuxt.jsで「Classic mode for store/ is deprecated and will be removed in Nuxt 3.」のエラーメッセージが表示される場合の対処法
JavaScriptのテンプレートリテラル内で条件分岐を行う方法
Gitで最初に設定しておくユーザー名とメールアドレスのグローバル設定
Local by Flywheelの「Starting Local Machine…」画面から進まないときに試すこと
Webサイト制作の基礎の基礎、HTMLって何?
WordPressのヘッダーにツールバーが表示されないときは、wp_headやwp_footerが入っているか確認
JavaScriptで配列内から特定条件の要素を探す方法
Visual Studio Codeの設定を複数の端末間で同期する「Settings Sync」機能の使い方
Visual Studio CodeでCSVの編集を見やすく行う拡張機能「Edit csv」
iTerm2で「Use System Window Restoration Setting」を設定しているとアラートが表示されて機能しない
Google Chromeのサイト内検索(カスタム検索)機能を別のプロファイルに移行する方法
iPadで入力モードを切り替えずに数字や記号をすばやく入力する方法
iPhoneやiPadでYouTubeの再生速度を3倍速や4倍速にする方法
Keynoteで有効にしているはずのフォントが表示されない現象
MacのKeynoteにハイライトされた状態でコードを貼り付ける方法
AirPodsで片耳を外しても再生が止まらないようにする方法
iTerm2でマウスやトラックパッドの操作を設定できる環境設定の「Pointer」タブ
DeepLで「インターネット接続に問題があります」と表示されて翻訳できないときに確認すること
Ulyssesの「第2のエディタ」表示を使って2つのシートを横並びに表示する
1つのノートアプリにすべて集約するのをやめた理由|2025年時点のノートアプリの使い分け
Notionログイン時の「マジックリンク」「ログインコード」をやめて普通のパスワードを使う
AlfredでNotion内の検索ができるようになるワークフロー「Notion Search」
Gitで1行しか変更していないはずのに全行変更した判定になってしまう
Macでアプリごとに音量を調節できるアプリ「Background Music」
Macのターミナルでパスワード付きのZIPファイルを作成する方法
MacBook Proでディスプレイのサイズ調整をして作業スペースを広げる
SteerMouseの「自動移動」機能で保存ダイアログが表示されたら自動でデフォルトボタンへカーソルを移動させる
iPhoneでタッチが一切効かなくなった場合に強制再起動する方法