31

ラジオボタン、テキスト、および選択の入力タイプを見つける必要があります。何でも入力タイプを見つけるのは簡単です<input type="x">$(this).attr("type")x

私の問題は<select>、type属性を持たない要素をサポートする必要があるということです。最終的な目標は、ラジオ、テキスト、または選択のいずれかを返すことです。

私はこのようなことをすることを考えましたが、もっと良い方法があるかどうか興味がありました:

if ($(this).tagName == "input") {
    var result = $(this).attr("type");   //returns radio or text (the attr type)
} else {
    var result = $(this).tagName;        //returns select (the element type)
}

皆さんありがとう!

4

2 に答える 2

70

これを行うことができ(ここでフィドル)、ある種の使いやすいプラグインを作成します:

$.fn.getType = function(){ return this[0].tagName == "INPUT" ? this[0].type.toLowerCase() : this[0].tagName.toLowerCase(); }

そして、このように使用します

$(".element").getType(); // Will return radio, text, checkbox, select, textarea, etc (also DIV, SPAN, all element types)
$(".elList").getType(); // Gets the first element's type

選択された最初の要素のタイプを取得します。

他の情報

セレクターが必要な場合は、次を使用できます。

$("input:text, input:radio, select");

または、すべてのフォームコントロールを選択します(詳細):

$(":input") // can return all form types
于 2012-02-02T17:15:42.567 に答える
7

すべてのタイプの入力ボックスと選択ボックスがjQueryによってまとめられます。

$('#myForm').find('select,input').each(function(i,box){
     alert($(box).attr('name'));
}
于 2018-10-08T07:41:17.040 に答える