0

私は探していたいくつかのアイデアをいじっていましたが、これに出くわしました: http://jsfiddle.net/RcrCJ/

元のhtml

        <div id="container">
          <div id="content">
          <ul id="info-nav">
                    <li><a href="#equipment_details"><span>Tab1</span></a></li>
                    <li><a href="#job_costs"><span>Tab2</span></a></li>
                    </ul>
            <div id="info">
            <form action="inex.html" method="post" id="form1" name="form1" class="formfields">
                <div id="equipment_details" class="hide">

                    <table border="0" cellspacing="1" cellpadding="2" id="tbl_equipment_details" width="100%">
                      <tr>
                        <td width="23%" class="txt-right">XXXX</td>
                        <td width="31%"><input type="text" name="" id="qw" /></td>
                      </tr>
                      <tr>
                        <td class="txt-right">XXX</td>
                        <td><input type="checkbox" id="" value="1" name="" checked=""></td>
                      </tr>
                      <tr>
                        <td class="txt-right">XXX XXX</td>
                        <td><input type="text" value="" name="" id="we" /></td>
                      </tr>
                    </table>
                    <!--tbl_equipment_details closed-->
            </div><!--div equipment_details closed-->

                <!--<div id="specifications" class="hide">-->
                <div id="job_costs" class="hide">
                    <table border="0" cellspacing="1" cellpadding="2" width="100%" id="tbl_specifications">
                      <tr>
                        <td width="18%" class="txt-right">Notes</td>
                        <td colspan="2" valign="top">
                            <textarea rows="3" id="description"  cols="60" name=""></textarea>                            </td>
                      </tr>
                      <tr>
                        <td class="txt-right">XXX</td>
                        <td width="39%">
                            <select name="purchased_from">
                                <option selected></option>
                                <option value="xxx">xxx1</option>
                                <option value="xxx">xxx2</option>
                                </select>                            </td>
                        <td class="txt-right">&nbsp;</td>
                      </tr>
                    </table>
              <!--</div>

                <div id="job_costs" class="hide">-->                        
                    <table border="0" cellspacing="0" cellpadding="0" width="100%">
                      <tr>
                        <td align="center">&nbsp;</td>
                      </tr>
                      <tr>
                        <td align="center">
                            <div>
                                <input value="Cancel" name="qq" type="button"> &nbsp;
                                <input value="Save Changes" name="ww" type="submit">
                            </div>                            </td>
                      </tr>
                    </table>
                </div><!--div feedback closed-->
              </form>
            </div><!--div info closed-->
        </div><!--div content closed-->
    </div><!--div container closed-->

オリジナルのジャバスクリプト

    $(document).ready(function(){
  $( '#info #job_costs' ).hide();

  $('#info-nav li').click(function(e) {
    $('#info .hide').hide();
    $('#info-nav .current').removeClass("current");
    $(this).addClass('current');

    var clicked = $(this).find('a:first').attr('href');
    $('#info ' + clicked).fadeIn('fast');
    e.preventDefault();
  }).eq(0).addClass('current');
});

それは私が探していたものとほとんど同じでしたが、もっと多くのタブが欲しかったのです。いじり始めたのですが、なぜか理解できないようで、3番目や4番目などのタブを追加して実行すると、いずれかをクリックするまですべてのタブが表示され、それは正常に見えます。ばかげたことだと思いましたが、これで何時間も遊んでいたに違いありません。

私はプロではありませんが、試行錯誤は得意です。これは、3 つのタブを作成するために一緒にハッキングしたものです: http://jsfiddle.net/cwaddilove/0Lo7jnoj/

修正されたhtml

<div id="container">
      <div id="content">
      <ul id="info-nav">
                <li><a href="#equipment_details"><span>Tab1</span></a></li>
                <li><a href="#job_costs"><span>Tab2</span></a></li>
                <li><a href="#job_assignment"><span>Tab3</span></a></li>
            </ul>
            <div id="info">
            <form action="inex.html" method="post" id="form1" name="form1" class="formfields">
                <div id="equipment_details" class="hide">

                    <table border="0" cellspacing="1" cellpadding="2" id="tbl_equipment_details" width="100%">
                      <tr>
                        <td width="23%" class="txt-right">XXXX</td>
                        <td width="31%"><input type="text" name="" id="qw" /></td>
                      </tr>
                      <tr>
                        <td class="txt-right">XXX</td>
                        <td><input type="checkbox" id="" value="1" name="" checked=""></td>
                      </tr>
                      <tr>
                        <td class="txt-right">XXX XXX</td>
                        <td><input type="text" value="" name="" id="we" /></td>
                      </tr>
                    </table>
                    <!--tbl_equipment_details closed-->
            </div><!--div equipment_details closed-->

                <!--<div id="specifications" class="hide">-->
                <div id="job_costs" class="hide">
                    <table border="0" cellspacing="1" cellpadding="2" width="100%" id="tbl_specifications">
                      <tr>
                        <td width="18%" class="txt-right">Notes</td>
                        <td colspan="2" valign="top">
                            <textarea rows="3" id="description"  cols="60" name=""></textarea>                            </td>
                      </tr>
                      <tr>
                        <td class="txt-right">XXX</td>
                        <td width="39%">
                            <select name="purchased_from">
                                <option selected></option>
                                <option value="xxx">xxx1</option>
                                <option value="xxx">xxx2</option>
                                </select>                            </td>
                        <td class="txt-right">&nbsp;</td>
                      </tr>
                    </table>
              <!--</div>

                <div id="job_costs" class="hide">-->                        
                    <table border="0" cellspacing="0" cellpadding="0" width="100%">
                      <tr>
                        <td align="center">&nbsp;</td>
                      </tr>
                    </table>
                </div><!--div feedback closed-->
                <div id="job_assignment" class="hide">
                    <table border="0" cellspacing="1" cellpadding="2" width="100%" id="tbl_assignment">
                      <tr>
                        <td width="18%" class="txt-right">Notes</td>
                        <td colspan="2" valign="top">
                            <textarea rows="3" id="assignment"  cols="60" name=""></textarea>                            </td>
                      </tr>
                      <tr>
                        <td class="txt-right">XXX</td>
                        <td width="39%">
                            <select name="sold_to">
                                <option selected></option>
                                <option value="xxx">xxx1</option>
                                <option value="xxx">xxx2</option>
                                </select>                            </td>
                        <td class="txt-right">&nbsp;</td>
                      </tr>
                    </table>
              <!--</div>

                <div id="job_costs" class="hide">-->                        
                    <table border="0" cellspacing="0" cellpadding="0" width="100%">
                      <tr>
                        <td align="center">&nbsp;</td>
                      </tr>
                      <tr>
                        <td align="center">
                            <div>
                                <input value="Cancel" name="qq" type="button"> &nbsp;
                                <input value="Save Changes" name="ww" type="submit">
                            </div>                            </td>
                      </tr>
                    </table>
                </div><!--div feedback closed-->
              </form>
            </div><!--div info closed-->
        </div><!--div content closed-->
    </div><!--div container closed-->

修正されたJavaScript

    $(document).ready(function(){
  $( '#info #job_costs #job_assignment' ).hide();

  $('#info-nav li').click(function(e) {
    $('#info .hide').hide();
    $('#info-nav .current').removeClass("current");
    $(this).addClass('current');

    var clicked = $(this).find('a:first').attr('href');
    $('#info ' + clicked).fadeIn('fast');
    e.preventDefault();
  }).eq(0).addClass('current');
});

誰かが私が間違ったことを見て、正しい方向に向けるのを手伝ってくれることを願っています.

ありがとうございます!

4

1 に答える 1

1

jQueryセレクターにエラーがあります:

$( '#info #job_costs #job_assignment' ).hide();

複数の要素を非表示にするには、次のようにセレクターの間にコンマを入れる必要があります。

$( '#info, #job_costs, #job_assignment' ).hide();

あなたの場合の解決策: 最初に 1 つが表示されるように、2 つのタブを非表示にするだけです。これは、コードで使用する必要があるものです。

$( '#job_costs, #job_assignment' ).hide();

ここには改善の余地がありますが、これでうまくいきます。ここに更新されたフィドルがあります

于 2014-08-17T18:54:43.597 に答える