Como eu determinaria se o elemento retornado por um filtro: input em jQuery é uma caixa de texto ou lista de seleção?
Quero ter um comportamento diferente para cada um (a caixa de texto retorna o valor do texto, a seleção retorna a chave e o texto)
Configuração de exemplo:
<div id="InputBody">
<div class="box">
<span id="StartDate">
<input type="text" id="control1">
</span>
<span id="Result">
<input type="text" id="control2">
</span>
<span id="SelectList">
<select>
<option value="1">Option 1</option>
<option value="2">Option 2</option>
<option value="3">Option 3</option>
</select>
</span>
</div>
<div class="box">
<span id="StartDate">
<input type="text" id="control1">
</span>
<span id="Result">
<input type="text" id="control2">
</span>
<span id="SelectList">
<select>
<option value="1">Option 1</option>
<option value="2">Option 2</option>
<option value="3">Option 3</option>
</select>
</span>
</div>
e então o script:
$('#InputBody')
// find all div containers with class = "box"
.find('.box')
.each(function () {
console.log("child: " + this.id);
// find all spans within the div who have an id attribute set (represents controls we want to capture)
$(this).find('span[id]')
.each(function () {
console.log("span: " + this.id);
var ctrl = $(this).find(':input:visible:first');
console.log(this.id + " = " + ctrl.val());
console.log(this.id + " SelectedText = " + ctrl.find(':selected').text());
});
jquery
jquery-selectors
amora
fonte
fonte
alternativamente, você pode recuperar propriedades DOM com
.prop
aqui está o código de amostra para a caixa de seleção
para caixa de texto
fonte
Se você quiser apenas verificar o tipo, você pode usar a função .is () do jQuery,
Como no meu caso, usei abaixo,
fonte