Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
2 / 2 / 0
Регистрация: 28.08.2012
Сообщений: 115

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

19.10.2013, 10:05. Показов 1394. Ответов 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): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru