質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

3559閲覧

vue.jsでclassの削除

退会済みユーザー

退会済みユーザー

総合スコア0

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/05/30 07:22

前提・実現したいこと

Vue.jsで3択問題を作っています。
ドットインストールのJavaScript講座で紹介されていた同じものをVue.jsで作ろうとしています。

正解を選んだ時にその要素にのみcorrect classを追加する処理を実装したのですが、
次の問題に行く時に、追加したcorrect classを削除したいのですが、上手くいきません。
JavaScriptだとclassList.removeだと思うのですが、vue.jsで実現するいい方法はないでしょうか?

該当のソースコード

html

1 2 <section id='app'> 3 <ul> 4 <li v-on:click="select(index,$event)" 5 v-for="(element,index) in elements" > 6 {{ element }} 7 </li> 8 </ul> 9 <div class="btn" v-on:click="remove">remove</div> 10 </section>

JavaScript

1 var vm = new Vue({ 2 el: '#app', 3 data: { 4 elements:['a1','a2'], 5 }, 6 methods: { 7 select: function (index, e) { 8 console.log("select clicked"); 9 e.currentTarget.className="correct"; 10 }, 11 remove: function (e) { 12 console.log("remove clicked") 13 } 14 }, 15 }); 16

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

こんな感じでしょうか?
v-bind:class にオブジェクトを渡すことで、そのオブジェクトの各要素について、キーに相当するクラスが値が truthy になった時に付与されるようになります。

参考: https://jp.vuejs.org/v2/guide/class-and-style.html

vue

1<section id='app'> 2 <ul v-on:click="select"> 3 <li 4 v-for="(element, index) in elements" 5 v-bind:class="{ correct: clickedIndex === index }" 6 > 7 {{ element }} 8 </li> 9 </ul> 10 <div class="btn" v-on:click="remove">remove</div> 11</section>

javascript

1var vm = new Vue({ 2 el: '#app', 3 data() { 4 return { 5 elements:['a1','a2'], 6 clickedIndex: null, 7 }; 8 }, 9 methods: { 10 select(ev) { 11 console.log("select clicked"); 12 this.clickedIndex = 13 [...ev.currentTarget.children].indexOf(ev.target); 14 }, 15 remove(e) { 16 console.log("remove clicked"); 17 this.clickedIndex = null; 18 } 19 }, 20});

なお、 data プロパティにオブジェクトをそのまま渡すと、コンポーネントを使い回したときに思わぬ挙動をすることがあるので、 data() 関数として実装することをおすすめします。

投稿2020/05/30 07:43

編集2020/05/30 07:45
htsign

総合スコア870

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/05/30 08:53

ありがとうございます!思った通りに動いてます! index番号でtrue/falseの判定をすればよかったんですね。 他にも、[...e.current... のところとか、data()についてとかも すごく勉強になりました! ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問