2017-06-13 16 views
0

私は、表示/非表示の動作を切り替えるボタンに結びつけられた一連のdivを持っています。親のdivを100vhに、個々のdivを50vhに調整しました。ユーザーの入力を確認して何とか右に移動したボタンを除いて、すべてが完全に表示されていました。私はさまざまな組み合わせを試してみました。個々のdivの中にボタンを置くことは、最終的には何をするのかです。今はもちろん、それぞれのdivの中にボタンが1つあるので、もはや機能しないIDのボタンがあります。各ボタンに異なるIDを付けることは、単一のクリックハンドラにアタッチされているため、オプションではありません。トグルボタンクラスのクリック機能

もちろん、私はクリックハンドラとIDが壊れているボタンが必要です。私はクラスを使用しようとし、クラスにクリックの振る舞いを追加して調べましたが、SOの提案は一切ありませんでした。私はクラス(ボタンがdiv idの子であるところ)で子セレクタを使ってみました。

ここでは、どのように動作したかのミニコードサンプルがあります。どのように私は各divの中に別のボタンを持ってどこに働くクリック機能(各ボタンのIDを分離することに頼らずに - それはidの多くでしょう)を持つことができますか?

HTML:

<div id="quiz" style="height:100vh;"> 
    <div id="divone" style="height:50vh;"> 
    Div One! 
    </div> 
    <div id="divtwo" style="display:none"> 
    Div Two! 
    </div> 
    <button id="clickything">Click me!</button> 
    </div 

JS/jQueryの:

var divs = ["divone", "divtwo", "divthree"] 
var i = 0 
$("#clickything").click(function() { 
    $("#" + divs[0]).hide(); 
    $("#" + divs[1]).show(); 
}) 
+0

達成しようとしているものは何ですか?ボタンをクリックし、div1とdiv2を切り替えますか? – Isac

+0

これは私がやっていることの簡略化されたバージョンです - 質問divがあり、ボタンは現在のdivを隠して結果divを表示し、結果divの別のボタンが結果を隠して次の質問を表示します。ボタンをクリックすると、現在の質問の結果が表示されます。結果が表示されている場合は、次の質問が表示されます。 – fstopzero

+0

一時的な修正として、私は各ボタンに独自のIDを与えましたが...これはスケーラブルな解決策ではありません。 – fstopzero

答えて

0

(それはクイズの場合)なぜ、代わりに質問にdiv要素をクリックする用途のボタンを使用します。

両方のdivは、あなたが他を隠すためにそれを使用することができ、親である場合には、より良い(目標の私の推論から)UIとシンプルなJS

だろう。

+0

私はあなたのことをよく理解していません。ボタンではない場合、ユーザーは何をクリックしますか? – fstopzero

+0

2つのdivのうちの1つです。 –

関連する問題