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

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

ただいまの
回答率

87.61%

JQuery:項目の追加・削除について

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 2,383

score 24

はじめまして。
JQueryを使用しボタンを押下した際の処理を書いているのですが、
上手く動作しないので分かる方がいればご教授頂けますか。

●処理内容
・初期状態では「備考」エリアは1つ表示されている
・項目を追加を押下すると「タイトル」と「内容」を含んだ「備考」エリアが追加される
・「備考」エリアが追加されるたびにタイトルの末尾は連番で振られる
・削除を押すと該当の「備考」エリアが削除される

●困っていること
「備考」エリアを3つ以上に増やし
2番目の「備考」エリアを削除すると、

タイトルが「備考3」のままになる、
inputのnameの末尾が3のままになる。
希望としてはタイトルやnameは連番にしたいのですが方法が分からないのでご教授頂けますか。

<script>
jQuery(document).ready(function($) {
  var prefix_order_list = 'order_list_'; // 品目入力欄のname属性の接頭辞

    // "品目の追加"ボタンを押した場合の処理
    $('#btn_add').click(function(){
        // 品目入力欄を追加
        var len_list = $('#order_list > div.list').length+1;

        // alert(len_list);

        var new_list = '<div class="list"><h3 class="tit03 col-xs-9 col-sm-10">' + '追加記述' + len_list + '</h3>';
            new_list += '<div class="col-xs-3 col-sm-2 button_del"></div>';
            new_list += '<div class="form-group col-xs-12">';
            new_list += '<label for="exampleInputName16" class="">タイトル</label>';
            new_list += '<input type="text" class="form-control " id="' + 'addtit' + len_list + '" placeholder="" name="'+ 'addtit' + len_list + '" >';
            new_list += '</div>';
            new_list += '<div class="form-group col-xs-12">';
            new_list += '<label for="'+ 'addcont' + len_list +'" class="">'+ '内容' +'</label>';
            new_list += '<textarea class="form-control " rows="3" id="' + 'addcontent' + len_list + '"' + 'name="' + 'addcontent' + len_list + '"></textarea>';
            new_list += '</div>';
            new_list += '</div>';

        $('#order_list').append(new_list);

        // 削除ボタンの一旦全消去し、配置し直す
        $('#order_list button').remove();
        len_list++;
        // alert(len_list);

        for (var i = 0; i < len_list; i++) {
             var new_btn = '<button type="button" class="btn btn-danger btn-block">削除</button>';

             $('#order_list > div .button_del').eq(i).append(new_btn);
        }
    });

    // 削除ボタンを押した場合の処理
    $(document).on('click', '#order_list button', function(ev) {
        // 品目入力欄を削除
        var idx = $(ev.target).parent().index();
        $('#order_list > div.list').eq(idx).remove();

        var len_list = $('#order_list > div.list').length;

        // 入力欄がひとつになるなら、削除ボタンは不要なので消去
        if (len_list == 1) $('#order_list button').remove();

        // 入力欄の番号を振り直す
        for (var i=0; i<len_list; i++) {
            $('#order_list > div.list').eq(i).children('button').attr('name', prefix_order_list + i);
            $('#order_list > div.list').eq(i).children('input[type="text"]').attr('name', prefix_order_list + i);
        }
    });
});
</script>
<form class="form-inline">
                <div class="row" id="order_list">

                    <div class="list">
                        <h3 class="tit03
                                    col-xs-9
                                    col-sm-10
                                    ">備考1</h3>


                        <div class="form-group col-xs-12">
                            <label for="addtit1" class="">タイトル</label>
                            <input type="text" class="form-control" id="addtit1" name ="addtit1" placeholder="">

                        </div>

                        <div class="form-group col-xs-12">
                            <label for="addcont1" class="">内容</label>
                            <textarea class="form-control " rows="3" id="addcontent1" name="addcontent1"></textarea>
                        </div>
                    </div>

                </div>




                <div class="row">

                    <div class="col-xs-12
                                col-sm-10
                                col-sm-offset-1
                                ">
                        <div class="row">

                            <div class="col-xs-12
                                    col-sm-6
                                    margin_b20
                                    ">
                                <button type="button" id="btn_add" class="btn btn-primary btn-lg btn-block">項目を追加</button>
                            </div>



                        </div>

                    </div>
            </form>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+2

$().children()は直下の子要素しか拾えないのでおそらくそこだと思います。

.children(*)


.find(*)


にかえてみてはどうでしょう。

ただこの場合i=0のとき存在しないノードを探しに行くのであまりおすすめできません。
→回避するにはiのオリジンナンバーを0ではなく1にするなどしてください。

あとは、他のかたの回答にもありますが同様の方法はいろいろあるのでぜひいろいろ検討してみてください。
個人的にデータバインディングはVueJSがおすすめです(学習コスト低いので)。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/23 15:13

    あ、あと、タイトルはそもそも書き換える処理がなかったので割愛しております。
    同様の手順でできるはずです。

    キャンセル

  • 2017/03/23 15:18

    なるほど!
    ただ、findに変更しても上手いこといかないんですよね。。。

    キャンセル

  • 2017/03/23 15:28

    うーん・・・?
    試してみたらうまくいっているように見えますが・・・
    ↓タイトルをiで置換している処理を加えています。

    https://jsfiddle.net/w2y2jvpL/

    キャンセル

+1

CSSで処理するとか、追加記述部分を取得して番号を振りなおすとかではないでしょうか。

【CSS カウンタの利用 - ウェブデベロッパーガイド | MDN】
https://developer.mozilla.org/ja/docs/Web/Guide/CSS/Counters

【CSS3で要素のカウントが出来るんだ・・・「counter-increment」がランキング作るのに便利 | わぃおがわ】
https://yogawa.com/post-4937

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/23 15:19

    ありがとうございます!
    参考にさせていただきます^^

    キャンセル

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

  • ただいまの回答率 87.61%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る