2 / 2 / 0
Регистрация: 28.08.2012
Сообщений: 115

display block для определенных id

19.10.2013, 10:05. Показов 1397. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть форма с селектом.
В нем выводятся option в таком виде:
HTML5
1
2
<option id="sec_4_cat_10" value="10" style="display:block;">Категории продукта3</option>
<option id="sec_5_cat_8" value="8" style="display:block;">Категории продукта2</option>
Нужно скрыть те option, где в id sec = 4, т.е в данном примере id="sec_4_cat_10". Я просто не знаю в какую сторону копать. Мысли такие, наверное как-то в цикле перебирать все id этого селекта, и проверять их через регулярку.
Подскажите пожалуйста мыслью, кодом, ну кто чем сможет))
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.10.2013, 10:05
Ответы с готовыми решениями:

Как отобразить скрытые элементы HTML(css-display:none;) используя JS!(display:block;)
&lt;!DOCTYPE html&gt; &lt;html lang=&quot;en&quot;&gt; &lt;head&gt; &lt;meta charset=&quot;UTF-8&quot;&gt; &lt;title&gt;AdBanner&lt;/title&gt; &lt;link rel=&quot;stylesheet&quot;...

Замена display:none; на display:block; при нажатии
Приветствую всех! Мои познания в JavaScript очень слабы, поэтому буду благодарен за любую помощь. Собственно есть некий html список, в...

display block display none onclick
когда я нажимаю на слово hello, с низу появляются новые слова. Я хочу, чтоб когда нажимать на слове hello, чтоб эти новые слова изчезли. То...

8
z-z
170 / 169 / 56
Регистрация: 22.06.2011
Сообщений: 980
19.10.2013, 10:25
izcian, это можно через обычный css сделать))

CSS
1
2
3
option[id^="sec_4"] {
/* ... */
}
это выражение действует на все option, у которых id начинается с выражения sec_4
0
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
19.10.2013, 10:33
z-z на 44 секунде произойдет непредвиденное Если все же только для 4 секунды, небольшой форк: option[id^="sec_4_"]
0
2 / 2 / 0
Регистрация: 28.08.2012
Сообщений: 115
19.10.2013, 11:08  [ТС]
Цитата Сообщение от z-z Посмотреть сообщение
izcian, это можно через обычный css сделать))

CSS
1
2
3
option[id^="sec_4"] {
/* ... */
}
это выражение действует на все option, у которых id начинается с выражения sec_4
Мне нужно по клику блокировать. И к сожалению нельзя сделать id="sec_4", поскольку их sec=4 может несколько штук будет. Валидатора ругаться будет...
0
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
19.10.2013, 11:12
JavaScript
1
2
3
4
5
6
7
8
9
10
11
var select = document.getElementById('products');
        var options = select.querySelectorAll('option');
 
        for(var i = 0; i < options.length; i++){
 
            if(options[i].id.indexOf('_4_')!=-1){
 
                options[i].style.display = "none";
            }
 
        }
1
2 / 2 / 0
Регистрация: 28.08.2012
Сообщений: 115
19.10.2013, 12:11  [ТС]
Цитата Сообщение от vovandr Посмотреть сообщение
JavaScript
1
2
3
4
5
6
7
8
9
10
11
var select = document.getElementById('products');
        var options = select.querySelectorAll('option');
 
        for(var i = 0; i < options.length; i++){
 
            if(options[i].id.indexOf('_4_')!=-1){
 
                options[i].style.display = "none";
            }
 
        }
Круто!! Спасибо огромное vovandr, я правда добавил
JavaScript
1
else { options[i].style.display = "block"; }
ну и вообщем еще раз спасибо!


По теме. Я почитал по querySelectorAll, интересно а его можно применить ко всей форме с чекбоксами, селектами, текстами? Просто у меня каждая поле имеет отношение к sec (id раздела). Вчера потратил весь день чтобы сделать зависимые поля от этого sec через ajax с json. (Т.е. при клике на раздел, в базе проверялось имеет ли отношение поле к этому разделу. Если нет, то display=" none" ну и наоборот.) А тут нарисовывается способ гораздо проще...

vovandr очень интересно Ваше мнение на этот счет.

Добавлено через 9 минут
Блин...Не работает в опере
0
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
19.10.2013, 12:25
Да без проблем. Он применяется к объетку и с помощью его искать в этом оюъетк необходимые элементы по селекторам аналогичным css

Добавлено через 10 минут
А не работает, потому что далеко не все браузеры позволяют скрывать теги option Вам лучше их удалять и вставлять Через removeChild. Это скорее всего единственный способ
0
2 / 2 / 0
Регистрация: 28.08.2012
Сообщений: 115
19.10.2013, 13:36  [ТС]
Цитата Сообщение от vovandr Посмотреть сообщение
А не работает, потому что далеко не все браузеры позволяют скрывать теги option Вам лучше их удалять и вставлять Через removeChild. Это скорее всего единственный способ
Ох уж эти браузеры ...Удаление и добавление потомков, ну эт для меня на следующем этапе развития))
0
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
19.10.2013, 13:40
JavaScript
1
2
3
4
5
6
7
8
9
10
11
var select = document.getElementById('products');
        var options = select.querySelectorAll('option');
 
        for(var i = 0; i < options.length; i++){
 
            if(options[i].id.indexOf('_4_')!=-1){
 
                options[i].parentNode.removeChild(options[i]);
            }
 
        }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.10.2013, 13:40
Помогаю со студенческими работами здесь

Не работает display: block;
Возникла проблема, хочу сделать на странице выбор базы данных (объект селект в диве) кнопками (две кнопки как меню), при нажатии на которые...

Не работает display: block под IE
Собственно вот код: &lt;style&gt; .sdan{ display:none; } &lt;/style&gt; &lt;form action=&quot;index.php&quot; name=&quot;sort&quot; method=&quot;post&quot;&gt; ...

Реализация el.style.display='block'; el.style.display='none';
Как реализовать следующие процедуры в указанных браузерах? el.style.display='block'; el.style.display='none';

Display: block; по клику на другом div
Первый опыт js, пока очень плохо разбираюсь. Не могу понять в чём допустил ошибку. Попробовал реализовать так: &lt;script...

Display: block при нажатии на ссылку
Добрый вечер, подскажите пожалуйста, есть скрипт который показывает блок при нажатии на ссылку var show; function look(type) { ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru