Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: element.children перебор dom элементов

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
ПТО
Отправлено: 27 Ноября, 2013 - 12:02:41
Post Id



Посетитель


Покинул форум
Сообщений всего: 395
Дата рег-ции: Янв. 2012  


Помог: 3 раз(а)




CODE (html):
скопировать код в буфер обмена
  1. <td id="newElem">
  2.     <input />
  3.     <input />
  4.     <textarea></textarea>
  5. </td>

CODE (javascript):
скопировать код в буфер обмена
  1.  
  2. var newElem,  inputs;
  3.  
  4. newElem = document.getElementById('newElem');
  5. inputs = newElem.children
  6.  
  7.     for (var key in inputs) {
  8.         console.log(inputs[key]);
  9.     }
  10.    

Возвращает помимо 2 инпутов и 1 текстареа еще и item, iterator, namedItem, __proto__, чего мне не надо. Хочу обойтись без жуквери. Как перебрать только input и textarea (а может и другие dom-элементы: div и т.д.)?
 
 Top
IllusionMH
Отправлено: 27 Ноября, 2013 - 12:23:46
Post Id



Активный участник


Покинул форум
Сообщений всего: 4254
Дата рег-ции: Февр. 2011  
Откуда: .kh.ua


Помог: 242 раз(а)




ПТО, хотите без jQuery - учите особенности циклов.
Либо перебирайте обычным циклом , с условием индекса меньше кол-ва элементов, либо модным, но с проверкой hasOwnProperty + проверка на название ключа, чтобы это была не длина.
Либо ждите ES6 и for...of

(Отредактировано автором: 27 Ноября, 2013 - 12:24:34)

 
 Top
nerv
Отправлено: 28 Ноября, 2013 - 13:34:36
Post Id



Посетитель


Покинул форум
Сообщений всего: 407
Дата рег-ции: Февр. 2013  
Откуда: Россия


Помог: 9 раз(а)




IllusionMH пишет:
Либо ждите ES6 и for...of

либо используйте es5

CODE (javascript):
скопировать код в буфер обмена
  1. Array.prototype.forEach(document.getElementById('newElem').children, function( child ) {
  2.    console.log( child )
  3. });


-----
Чебурашка стал символом олимпийских игр. А чего достиг ты?
Тишина - самый громкий звук
 
 Top
ПТО
Отправлено: 28 Ноября, 2013 - 14:35:27
Post Id



Посетитель


Покинул форум
Сообщений всего: 395
Дата рег-ции: Янв. 2012  


Помог: 3 раз(а)




CODE (javascript):
скопировать код в буфер обмена
  1. for (var i = 0; i < inputs.length; i++) {
  2.         console.log(inputs[i]);
  3. }
  4.    
 
 Top
armancho7777777 Супермодератор
Отправлено: 28 Ноября, 2013 - 19:50:21
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




IllusionMH, достаточно проверить свойство nodeType, или пройтись итерацией как в последнем примере.
 
 Top
IllusionMH
Отправлено: 28 Ноября, 2013 - 20:09:42
Post Id



Активный участник


Покинул форум
Сообщений всего: 4254
Дата рег-ции: Февр. 2011  
Откуда: .kh.ua


Помог: 242 раз(а)




armancho7777777, ну это и было первым вариантом.
IllusionMH пишет:
Либо перебирайте обычным циклом , с условием индекса меньше кол-ва элементов
 
 Top
armancho7777777 Супермодератор
Отправлено: 28 Ноября, 2013 - 20:23:13
Post Id



Активный участник


Покинул форум
Сообщений всего: 4526
Дата рег-ции: Февр. 2011  
Откуда: Москва


Помог: 221 раз(а)




А, ну да.
Пропустил, не заметил.
Проснулся только )
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« JavaScript & VBScript »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB