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

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

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

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

Q&A

1回答

192閲覧

for文で表示させた数個のボタンから、クリック前 かつ 先頭のボタンのみに常に文言を追加表示したい。

退会済みユーザー

退会済みユーザー

総合スコア0

Vue.js

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

0グッド

0クリップ

投稿2019/08/13 06:55

前提・実現したいこと

v-forでボタンを数個、左から並べて表示し、クリック後と前でイベントを分けています。
①クリックされていない状態のボタンの中から
②一番左のボタンのみ
に、ボタンの下に文言を表示したいです。

例えば三つボタン並んでいるとして、ユーザはそれを順番関係なしにクリックできます。クリックするとそのボタンは clicked になります。
[1][2][3]とボタンがあるとした場合、
最初は1の下に文言。1をクリック後は2の下に文言。1ではなく2 or 3をクリックし場合文言は1の下のまま。
というのを実現したいです。

該当のソースコード

vue.js

1<div> 2 <btn 3 v-for="(hoge, index) in hoges" 4 :key="hoge.id" 5 role="button" 6 class="btn" 7 @click="clicked(index)" 8 > 9 <template v-if="!clicked"> 10 <div> 11 <p>これをボタンの下に表示したい<p> 12 </div> 13 </btn> 14</div>

何ができないのか

現在はクリック前全てのボタンの下に文言が表示されています。
全てのボタンの下ではなく、クリック前かつ一番左のボタンのみの下に文言を出したいのですが、どう記述すればよいのかわからず困っています。

よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

仕様としてはclickedになっていない最小インデックスの要素に文言を表示したいという認識でいいでしょうか?
hogeのデータがどうなっているかが分からないのですが、以下のような形ではどうでしょうか。

vue

1<template> 2 <btn 3 v-for="(hoge, index) in hoges" 4 :key="hoge.id" 5 role="button" 6 class="btn" 7 @click="clicked(index)" 8 > 9 <template v-if="unClickedIndex === index"> 10 <div> 11 <p>これをボタンの下に表示したい<p> 12 </div> 13 </template> 14 </btn> 15</template> 16 17<script> 18export default { 19 data() { 20 return { 21 hoges: [] 22 } 23 }, 24 computed: { 25 unClickedIndex() { 26 this.hoges.findIndex(el => el.clicked !== true) 27 } 28 } 29} 30</script> 31

投稿2019/08/26 08:38

nt4c

総合スコア768

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問