JQuery - определить, является ли элемент ввода текстовым полем или выбрать список
Как я могу определить, является ли элемент, возвращаемый фильтром ввода: jQuery, текстовым полем или списком?
Я хочу иметь другое поведение для каждого (текстовое поле возвращает текстовое значение, select возвращает оба ключа и текст)
Пример настройки:
<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>
а затем 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());
});
Ответы
Ответ 1
Вы можете сделать это:
if( ctrl[0].nodeName.toLowerCase() === 'input' ) {
// it was an input
}
или это, что медленнее, но короче и чище:
if( ctrl.is('input') ) {
// it was an input
}
Если вы хотите быть более конкретным, вы можете проверить тип:
if( ctrl.is('input:text') ) {
// it was an input
}
Ответ 2
в качестве альтернативы вы можете получить свойства DOM
с .prop
здесь пример кода для блока выбора
if( ctrl.prop('type') == 'select-one' ) { // for single select }
if( ctrl.prop('type') == 'select-multiple' ) { // for multi select }
для текстового поля
if( ctrl.prop('type') == 'text' ) { // for text box }