0

私は次のフォームを持っています

 <form action="test.php" id="loginform" name="loginform" method="post">
     <input name="title[]" id="title1" type="text" value="" tabindex="1" />
     <input name="title[]" id="title2" type="text" value="" tabindex="2" />
     <input  name="title[]" id="title3" type="text" value="" tabindex="3" />
     <input type="submit" name="submit" value="Submit" id="submit" tabindex="4" />
 </form>

このコードを使用して要素名を取得することはできますが、IDを取得することはできません。

$('#loginform').bind('submit', function() { 
    var elements = $(this).serializeArray();
    $.each(elements, function(i, element) {
        var temp = $('#' + element['name']);
        var name = this.name; alert(name);
        var id = this.id; alert(id); ///even id = this.attr("id"); not getting

        var value = this.value; 
        (temp.val() == '') ? temp.css({'background': '#FFC4C4', 'border': '1px solid #F00'}) : temp.removeClass('hightlight');
    });
    return false;
});

デモ

4

1 に答える 1

1

あなたのためにこれに関する答えを更新します:

このコード:

var id = $(this).id;alert(id);

これになるはずです:

var id = $('input[name="' + name + '"]').attr("id");
alert(id);

ここで機能するコードを参照してください:http://jsfiddle.net/Ct8zf/5/

.serializeArray()のドキュメントによると、シリアル化される要素は名前と値のみであることに注意してください。

お役に立てれば。

于 2011-01-27T09:40:41.770 に答える