0 / 0 / 0
Регистрация: 26.06.2015
Сообщений: 159

Работа с select: это нужно делать через $().val(); или через .change()?

03.11.2016, 23:04. Показов 1440. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть такая форма на сайте.
Если значение поля "Тип организации куда нужна справка" любое кроме "другой тип", то поле "Название организации" не активно и ему присваивается css свойство border-color:red;.
Если выбрано другой тип, то поле "Название организации" активно и имеет css свойство border-color:#888888;.
Не понятно, это нужно делать через $().val(); или через .change()?
Если первое то у меня получается так. Не работает.

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
var result
result=$('[name="menu-944"]').val();
if (result=='Другой тип') {
    $('[name="text-319"]').css("border-color", "blue");
    $('[name="text-319"]').prop(
     {'disabled': false}
     )
}
else {
    $('[name="text-319"]').css("border-color", "red");
}   $('[name="text-319"]').prop(
     {'disabled': true}
     )
Если второе то у меня получается так и не работает тоже.
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
var result
result=$('[name="menu-944"]').change(function() {
if (result=='Другой тип') {
    $('[name="text-319"]').css("border-color", "blue");
    $('[name="text-319"]').prop(
     {'disabled': false}
     )
}
else {
    $('[name="text-319"]').css("border-color", "red");
}   $('[name="text-319"]').prop(
     {'disabled': true}
     )
};
Подскажите как правильно.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.11.2016, 23:04
Ответы с готовыми решениями:

Отслеживать change нескольких select
Привет. Задача: в зависимости от выбранного аэропорта отображать/скрывать селектор терминала,...

Установка событий в цикле (установка change на select при обходе массива DIV)
Нужно обходя дивы (DIV) навесить chang на select срабатывает только на первом диве остальные не...

onChange, если его Enter-ом, так 'on' совсем HE 'Change', чудные дела
Конструкция элементарная. В форме для полей ввода стоит: <input id="h_ххх" type="text"...

3
 Аватар для vettel
84 / 84 / 41
Регистрация: 14.02.2015
Сообщений: 320
04.11.2016, 00:14
Лучший ответ Сообщение было отмечено sergey_ku как решение

Решение

Цитата Сообщение от sergey_ku Посмотреть сообщение
это нужно делать через $().val(); или через .change()?
Для начала, разберитесь между обработчиком события change() и взятием значения поля val(). Это две большие разницы.
val() - это просто считать значение поля, а change() - это обработчик события, который вызывается тогда, когда селект изменяется юзверем.

А код у вас в целом правильный, но допущена синтаксическая ошибка на вашем сайте, на которую ругается консоль (смотрите почаще в консоль).
Вот это должно работать:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
$('[name="menu-944"]').change(function() {
    var result = $(this).val();
    if (result=='Другой тип') {
        $('[name="text-319"]').css("border-color", "blue");
        $('[name="text-319"]').prop(
         {'disabled': false}
        )
    } else {
        $('[name="text-319"]').css("border-color", "red");
        $('[name="text-319"]').prop(
           {'disabled': true}
         )
    }
});
1
0 / 0 / 0
Регистрация: 26.06.2015
Сообщений: 159
04.11.2016, 10:09  [ТС]
Спасибо!
А как запустить этот код при загрузке страницы?
Сейчас он срабатывает только после выбора значения поля name="menu-944"
0
 Аватар для vettel
84 / 84 / 41
Регистрация: 14.02.2015
Сообщений: 320
04.11.2016, 14:23
Лучший ответ Сообщение было отмечено sergey_ku как решение

Решение

Цитата Сообщение от sergey_ku Посмотреть сообщение
Сейчас он срабатывает только после выбора значения поля name="menu-944"
Ну да, так и есть. сейчас весь код находится в обработчике события, стало быть выполняется только при срабатывании этого самого события.
Для решения вашей проблемы можно вынести данный код в отдельную функцию:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function selectOrg() {
    var result = $('[name="menu-944"]').val();
    if (result=='Другой тип') {
        $('[name="text-319"]').css("border-color", "blue");
        $('[name="text-319"]').prop(
         {'disabled': false}
        )
    } else {
        $('[name="text-319"]').css("border-color", "red");
        $('[name="text-319"]').prop(
           {'disabled': true}
         )
    }
}
А потом вызывать ее при загрузке страницы и при изменении выбора в селекте:
JavaScript
1
2
3
4
5
6
$(document).ready(function() {
    selectOrg(); //вызываем при загрузке страницы
    $('[name="menu-944"]').change(function() {
        selectOrg();//вешаем ф-ю на обработчик, чтобы она срабатывала при изменении селекта
    });
});
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.11.2016, 14:23
Помогаю со студенческими работами здесь

Нужно сделать так чтобы при выборе некоторых значений в первом select, изменялись значения второго select
Помогите пожалуйста мне нужно сделать так чтобы при выборе некоторых значений в первом select,...

При выборе какого-то значения в select'e нужно показывать другой select рядом
Здравствуйте, я полный ноль в js, но нужно следующее: На сайте есть разделы. При выборе какого-то...

В django нужно сделать чтобы при выборе некоторого значений в select-1, данные подгружались уже для select-2 и наоборот
Коллеги всем привет !!! Нужна ваша помощь: Есть приложение на django (личный кабинет) ...

Вызов ng-change через js
<div ng-controller="MyTestCtrl"> <input id="test" ng-model="ModelValue"...

Отслеживание изменений полей формы через событие change в попапе
Всем добрый вечер! У меня есть сайт со всплывающими формами. У него есть формы, которые...


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

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

Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru