Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Помогите составить скрипт вывода зависимых друг от друга списков!
 
 автор: sega_z   (08.05.2011 в 15:53)   письмо автору
 
 

Есть два зависимых списка:


<?php
<select name="region" size="1" class="pole" id="region">
<
option value="<?php echo @$region?>"><?php echo @$region?></option>
<option value="Свердловская область">Свердловская область</option>
<option value="Московская область">Московская область</option>

<select name="gorod" size="1" class="pole" id="gorod">
<option value="<?php echo @$gorod ?>"><?php echo @$gorod ?></option>
<option value="Екатеринбург">Екатеринбург</option>
<option value="Нижний Тагил">Нижний Тагил</option>
<option value="Москва">Москва</option>
<option value="Балашиха">Балашиха</option>
?> 


Помогите составить PHP скрипт для выборки из Mysql "Региона" и соответствующих ему городов "Город" во втором списке.

Таблица типа:

id, region_tabl, gorod_tabl
1, Свердловская область, Екатеринбург
2, Свердловская область, Нижний новгород
3, Московская область, Москва
4, Московская область, Балашиха

  Ответить  
 
 автор: cheops   (08.05.2011 в 16:06)   письмо автору
 
   для: sega_z   (08.05.2011 в 15:53)
 

Возможно вас заинтересуют темы по ссылкам
http://softtime.ru/forum/read.php?id_forum=3&id_theme=7586
http://softtime.ru/forum/read.php?id_forum=4&id_theme=12222

  Ответить  
 
 автор: sega_z   (08.05.2011 в 16:12)   письмо автору
 
   для: cheops   (08.05.2011 в 16:06)
 

Спасибо! Попробую разобраться...

  Ответить  
 
 автор: sega_z   (08.05.2011 в 20:02)   письмо автору
 
   для: sega_z   (08.05.2011 в 16:12)
 

Что никто не поможет...?

  Ответить  
 
 автор: sega_z   (08.05.2011 в 18:07)   письмо автору
 
   для: cheops   (08.05.2011 в 16:06)
 

Нашел одну подходящую функцию, работает нормально.
Но:
1) после перезагрузки страницы поле город становится не активным и для того, чтобы снова выбрать город, необходимо заново выбрать регион.
2) в некоторых браузерах в поле город отображается регион

Подскажите, как это исправить???

Вот JAVA:


function mF ()
{
var slc_1 = document.getElementById ('region'), slc_2 = document.getElementById ('gorod');
if (!slc_1.selectedIndex) {slc_2.selectedIndex = 0; slc_2.disabled = 1; return}
if (!self.Gslc_2)
   {
   Gslc_2 = []; for (var j = 0, obj = slc_2.options, lj = obj.length; j < lj; j++)
   {Gslc_2 [j] = []; Gslc_2 [j].label = obj [j].label; Gslc_2 [j].value = obj [j].value; Gslc_2 [j].text  = obj [j].text}
   var w = Math.max (slc_1.offsetWidth, slc_2.offsetWidth); slc_1.style.width = slc_2.style.width = w + 'px';
   }
for (var rbr = slc_1.options [slc_1.selectedIndex].value, new_slc_2 = [], j = k = 1, lj = Gslc_2.length; j < lj; j++)
if (Gslc_2 [j].label == rbr) {new_slc_2 [k] = []; new_slc_2 [k].value = Gslc_2 [j].value; new_slc_2 [k++].text = Gslc_2 [j].text}
new_slc_2 [0] = Gslc_2 [0];
for (var j = slc_2.options.length - 1; j >= 0; j--) slc_2.options [j] = null;
for (var j = 0; j < new_slc_2.length; j++)
   {
   var opt = document.createElement ('option'); opt.value = new_slc_2 [j].value; opt.text = new_slc_2 [j].text;
   slc_2.options.add (opt);
   }
slc_2.disabled = 0;



А вот часть самого списка (всего 86 регионов):


<select name="region" size="1" class="pole" id="region" onchange="mF ()">
<option value="<?php if (empty ($_SESSION['gorod']) and empty ($_POST['gorod'])) {echo "";} else {echo @$_POST['region'];}?>"><?php if (empty ($_SESSION['gorod']) and empty ($_POST['gorod'])) {echo "";} else {echo @$_POST['region'];}?></option>
<option value="Республика Адыгея">Адыгея</option>  
<option value="Республика Алтай">Алтай (Республика)</option>
<option value="Алтайский край">Алтайский край</option>
<option value="Амурская область">Амурская область</option>
</select>


<select name="gorod" size="1" class="pole" id="gorod" disabled>
                      <option label="<?php echo @$_POST['region'?>" value="<?php if (!empty ($_POST['gorod'])) {echo $_POST['gorod']; $_SESSION['gorod']=$_POST['gorod'];} else {echo $_SESSION['gorod'];}?>">
                        <?php if (!empty ($_POST['gorod'])) {echo $_POST['gorod']; $_SESSION['gorod']=$_POST['gorod'];} else {echo $_SESSION['gorod'];}?>
                      </option>
                      <option label="Республика Адыгея" value="Адыгейск">Адыгейск</option>
                      <option label="Республика Адыгея" value="Майкоп">Майкоп</option>
                      <option label="Республика Алтай" value="Горно-Алтайск">Горно-Алтайск</option>
                      <option label="Алтайский край" value="Алейск">Алейск</option>
                      <option label="Алтайский край" value="Барнаул">Барнаул</option>
                      <option label="Алтайский край" value="Белокуриха">Белокуриха</option>
                      <option label="Алтайский край" value="Бийск">Бийск</option>
                      <option label="Алтайский край" value="Горняк">Горняк</option>
                      <option label="Алтайский край" value="Заринск">Заринск</option>
                      <option label="Алтайский край" value="Змеиногорск">Змеиногорск</option>
                      <option label="Алтайский край" value="Камень-на-Оби">Камень-на-Оби</option>
                      <option label="Алтайский край" value="Новоалтайск">Новоалтайск</option>
                      <option label="Алтайский край" value="Рубцовск">Рубцовск</option>
                      <option label="Алтайский край" value="Славгород">Славгород</option>
                      <option label="Алтайский край" value="Яровое">Яровое</option>
                      <option label="Амурская область" value="Белогорск">Белогорск</option>
                      <option label="Амурская область" value="Благовещенск">Благовещенск</option>
                      <option label="Амурская область" value="Завитинск">Завитинск</option>
                      <option label="Амурская область" value="Зея">Зея</option>
                      <option label="Амурская область" value="Райчихинск">Райчихинск</option>
                      <option label="Амурская область" value="Свободный">Свободный</option>
                      <option label="Амурская область" value="Сковородино">Сковородино</option>
                      <option label="Амурская область" value="Тында">Тында</option>
                      <option label="Амурская область" value="Шимановск">Шимановск</option>
</select>

  Ответить  
 
 автор: sega_z   (08.05.2011 в 21:00)   письмо автору
 
   для: sega_z   (08.05.2011 в 18:07)
 

Что никто не поможет...?

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования