|
|
|
| Есть два зависимых списка:
<?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 в 16:12)
| | Что никто не поможет...? | |
|
|
|
|
|
|
|
для: 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 в 18:07)
| | Что никто не поможет...? | |
|
|
|