1

jQuery を使用してアプリケーションを作成しています。ボタンをクリックすると、選択ボックスが生成されて行に追加されます。選択が変更されるたびに、変更イベントをトリガーする必要がありますが、使用.on("change", function() {});は機能しません:

コード:

<!DOCTYPE html>
<html>
    <head>
        <title>HTML5-Template</title>
        <meta http-equiv="content-type" content="text/html; charset=utf-8">
        <style type="text/css">
            html, body
            {
            }

            input,select {
                border: 1px solid #404048;
                padding: 4px;
            }
        </style>
        <script type="text/javascript" src="../JavaScript/JQuery/jquery-1.9.1.js"></script>
        <script type="text/javascript">
            $(document).ready(function() {
                $("#cmdCreateRow").click(function() {
                    var row = $("<div />")
                    .css("font", "normal 12px Verdana")
                    .css("padding", "8px")
                    .css("display", "inline-block")
                    .css("background", "#F0F0F8")
                    .css("border", "1px solid #A0A0A8")
                    .css("margin", "2px");

                    var types = [
                        "Local", 
                        "Remote",
                        "(Custom)"
                    ];

                    var type = $("<select />").attr("class", "member-type");
                    for(var i in types) {
                        type.append($("<option />").val(types[i]).text(types[i]));
                    };

                    row.append(type);

                    $("#Container").append(row).append($("<br />"));
                });

                $(".member-type").on("change", function() {
                    alert("changed");
                });
            });
        </script>
    </head>
    <body>
        <input type="button" id="cmdCreateRow" value="Create Row" />
        <div id="Container">
        </div>
    </body>
</html>

私が間違っていることは何ですか?

4

2 に答える 2

9

バインディングを行うときは空であるため$(".member-type")、何もしていません。

変化する

$(".member-type").on("change", function() {
       alert("changed");
});

$(document).on("change", ".member-type", function() {
         alert("changed");
});

またはこれは #Container 要素が静的であるためです。

$("#Container").on("change", ".member-type", function() {
         alert("changed");
});
于 2013-05-30T13:34:56.607 に答える
1

これを試して:

$(document).on("change", ".member-type", function() {
    //Code
});

これは、jQuery の "live" の代替です。http: //api.jquery.com/live/を参照してください。

--

通常の「on」メソッドは、DOM で既に使用可能な要素に対してのみ機能します。

于 2013-05-30T13:36:01.970 に答える