Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 26

.val() Не забирает текстовые значения из select

03.10.2014, 23:58. Показов 948. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Делаю бд на пхп и javascript. На странице ajax.base.php есть 3 селекта. В первый нужно передать фамилии из таблицы pokupatel без повторяющихся значений. Во второй вывести фамилии из той же таблицы pokupatel, соответствующие имени, которое выбрано в первом, . В третий вывести номер паспорта из pokupatel, соответствующий фамилии и имени, выбранных в первых двух селектах.
Код элемента ajax.base.php :
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
 <div>
      <label>Выберите имя</label><br />
      <select name="namedropdown" id="namedropdown">
      <option value="">Выберите имя</option>
         <?           
         
        
           $rez= mysql_query ("SELECT DISTINCT pok_id,firstname FROM pokupatel ");
          
              while ($row=mysql_fetch_array($rez))
         {     
             
                  echo"<option value=\"".$row["pok_id"]."\">".$row["firstname"]."</option>";
             
        
         }
         ?>
      </select>
   </div>
Код скрипта :
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
$(document).ready(function() {
    $("#namedropdown").change(function() {
        var namevalue = $("#namedropdown option:selected").val();
        if (namevalue == '') {clearlist();}
        getfirstname();
    })
    $("#lastnamedropdown").change(function() {
        getpassport();
    })
}
 
);
 
function getfirstname() {
    var namevalue = $("#namedropdown option:selected").val();
    var lastname = $("#lastnamedropdown");
    if (namevalue == 0) {
        lastname.attr("disabled",true);
        getcity();
    } else {
 
        lastname.attr("disabled",false);
        lastname.load('getlastname.php',{name : namevalue});
    }
    
}
function getpassport() {
    var namevalue = $("#namedropdown option:selected").val();
    var lastname= $("lastnamedropdown option:selected").val();
    var passport = $("#passportdropdown");
    if (countryvalue == 0) {
        passport.attr("disabled",true);
    } else {
        passport.attr("disabled",false);
        passport.load('getpassport.php',{lastname : lastname});
    }
}
function clearlist() {
    $("#areadropdown").empty();
    $("#passportdropdown").empty();
}
Код php страницы, на которую ссылается скрипт:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
<?php
include("connect.phtml");
$name=$_POST["name"];
print $name;
$fak = mysql_query("SELECT  lastname FROM pokupatel WHERE pok_id=".$name) or die("sss");
echo "<option value\"\">Выберите фамилию</option>";
while ($es= mysql_fetch_array ($fak)) 
{  
    echo "<option value=\"".$es["pok_id"]."\">".$es["lastname"]."</option>";
}
 
?>
Так все работает, но в первую таблицу выводятся повторяющиеся значения, потому что очевидно, что айдишники у покупателей с однаковым именем разные. Пробовал сделать так :
SQL
1
"SELECT DISTINCT firstname FROM pokupatel
. Это тоже работает : выводятся все существующие в таблице имена без повторений, но айдишник не передается, поэтому в value нужно передавать firstname и переделать запрос на странице getlastname.php в следующий :
SQL
1
"SELECT pok_id, lastname FROM pokupatel WHERE firstname=".$name
Попробовал, но почему-то в переменную $name не передается значение firstname из первого списка. Почитал документацию .val(), написано, что должен передавать все. Помогите пожалуйста
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.10.2014, 23:58
Ответы с готовыми решениями:

Select option[val] не работает
Посмотрите этот код и скажите почему может не срабатывать сам код http://jsfiddle.net/Hey4/GxCbb/3/ сайт...

Не выводится val() из тега <select>
Беда с val() в &lt;select&gt;. Вот код: &lt;div class=&quot;blockTxt&quot;&gt; &lt;div class=&quot;btnFood&quot;&gt; &lt;select class=&quot;quantity-select&quot;&gt; ...

Не работает функция val() у select-элемента из массива
Не понимаю, почему не работает этот код. На форме несколько select (количество может быть разное), необходимо сравнить выбранные значения...

4
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 26
05.10.2014, 06:17  [ТС]
Выяснил, что значение firstname передается, если указать его в value. Но дальше не пойму в чем проблема. Предполагаю, что не делается выборка из бд по firstname.

Добавлено через 16 минут
В общем, переделал код страницы getlastname.php на такой :
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?php
include_once("connect.phtml");
$name=$_POST["name"];
if ($array = mysql_query("SELECT lastname FROM pokupatel
                     WHERE firstname=".$name)==true){
 while ($m = mysql_fetch_array($array))
     {
        echo ("<option>1</option>");
        
    }
    }
    else{
echo "<option value\"\">$name</option>";
 
  }
  
  
  ?>
Срабатывает else в списке lastnamedropdown на странице ajax.base.php. Помогите пожалуйста. Я совсем запутался.
0
Невнимательный
 Аватар для ft4l
3107 / 1282 / 358
Регистрация: 08.02.2013
Сообщений: 7,505
Записей в блоге: 2
05.10.2014, 06:17
<select name="namedropdown"
.....
$name=$_POST["name"];
print $name;
$fak = mysql_query("SELECT pok_id, lastname FROM pokupatel WHERE pok_id=".$name)
1
1 / 1 / 0
Регистрация: 25.09.2014
Сообщений: 26
05.10.2014, 06:57  [ТС]
СПС за то, что отписался. В общем токо что сам решил проблему, оказывается для выбора значений не по цифрам(например айдишнику), а по текстовым переменным ( в моем случае - имя), нужно делать выборку через LIKE.
$fak = mysql_query("SELECT lastname, pok_id FROM pokupatel WHERE firstname LIKE '$name' ");
while ($es=mysql_fetch_assoc($fak)){
echo "<option value=\"".$es["pok_id"]."\">".$es["lastname"]."</option>";

}
0
Невнимательный
 Аватар для ft4l
3107 / 1282 / 358
Регистрация: 08.02.2013
Сообщений: 7,505
Записей в блоге: 2
05.10.2014, 07:34
Напишите вместо print $name;
PHP
1
2
3
echo '<pre><xmp>';
var_dump($_POST);
echo '</xmp></pre>';
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.10.2014, 07:34
Помогаю со студенческими работами здесь

Какое условие сделать чтобы от выбранного значения в select другой select принимал определенные значения?
выбираем например книгу и потом во втором select должно изменится значение &lt;label for=&quot;username&quot;&gt;Наименование...

Условие val>7 выполняется и тогда, когда val<=7 минимум один раз?
Доброго времени суток. Написал программу по вот этой вот теме, на простых циклах и ветвлениях. Но что-то с ней не так- в комментариях к...

Что означает строчка кода val = val & 0xF; ?
Что означает строчка кода? val = val &amp; 0xF; Не понятно использование оператора &amp;

Double val = 83.1*3; val == 249.29999999999998; Android так считает
Double val = 83.1*3; Log.i(&quot;M&quot;,&quot;val = &quot;+val); M: val = 249.29999999999998 В чем фишка? Или это я в школе на математике...

Пустые значения val()
Здравствуйте! Сделал вот такую форму: &lt;!-- Диалог редактирования проекта --&gt; &lt;div id=&quot;projectEditDlg&quot;&gt; ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru