С Новым годом! Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
McS

Некорректная работа с id в IE6/7

10.04.2011, 14:45. Показов 1344. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть форма, в зависимости от выбора Способа доставки в этой форме, для пользователя должны отображаться различные поля контактных данных. В FF, Опере и Хроме все работает корректно, но в IE 6/7 почему то реагирует на клик с задержкой (обрабатывается предпоследний клик) и видимым также становится поле "Город", второе по счету из обрабатываемых, вместо "Названия полей для самовывоза".
Код:

HTML5
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
<script type="text/javascript">
 
function seldost (selectdost){
var useragent=navigator.userAgent;
if (useragent.indexOf('MSIE')!= -1)
{if ((selectdost)=="samovivoz") {
 
document.getElementById("samov").style.display = 'block';
document.getElementById("dost_mosobl").style.displ ay = 'none';
document.getElementById("dost_reg").style.display = 'none';
document.getElementById("city").style.display = 'none';
document.getElementById("index").style.display = 'none';
document.getElementById("street").style.display = 'none';
document.getElementById("house").style.display = 'none';
document.getElementById("building").style.display = 'none';
document.getElementById("flat").style.display = 'none';
}
 
else {
 
document.getElementById("city").style.display = 'block';
document.getElementById("index").style.display = 'block';
document.getElementById("street").style.display = 'block';
document.getElementById("house").style.display = 'block';
document.getElementById("building").style.display = 'block';
document.getElementById("flat").style.display = 'block';
}
if ((selectdost)=="dost_msk")
{
document.getElementById("samov").style.display = 'none';
document.getElementById("dost_mosobl").style.displ ay = 'block';
document.getElementById("dost_reg").style.display = 'none';
}
if ((selectdost)=="dost_rg")
{
document.getElementById("samov").style.display = 'none';
document.getElementById("dost_mosobl").style.displ ay = 'none';
document.getElementById("dost_reg").style.display = 'block';
}
}
else
{
 
if ((selectdost)=="samovivoz") {
 
document.getElementById("samov").style.display = 'table-row';
document.getElementById("dost_mosobl").style.displ ay = 'none';
document.getElementById("dost_reg").style.display = 'none';
document.getElementById("city").style.display = 'none';
document.getElementById("index").style.display = 'none';
document.getElementById("street").style.display = 'none';
document.getElementById("house").style.display = 'none';
document.getElementById("building").style.display = 'none';
document.getElementById("flat").style.display = 'none';
}
 
else
{
 
document.getElementById("city").style.display = 'table-row';
document.getElementById("index").style.display = 'table-row';
document.getElementById("street").style.display = 'table-row';
document.getElementById("house").style.display = 'table-row';
document.getElementById("building").style.display = 'table-row';
document.getElementById("flat").style.display = 'table-row';
}
if ((selectdost)=="dost_msk")
{
document.getElementById("samov").style.display = 'none';
document.getElementById("dost_mosobl").style.displ ay = 'table-row';
document.getElementById("dost_reg").style.display = 'none';
}
if ((selectdost)=="dost_rg")
{
document.getElementById("samov").style.display = 'none';
document.getElementById("dost_mosobl").style.displ ay = 'none';
document.getElementById("dost_reg").style.display = 'table-row';
}
}
}
</script>
 
<!-- html код -->
 
<body>
<strong>Контактные данные</strong>
 
<form id="form1" name="form1" method="post" action="">
<table width="98%" border="0" cellpadding="0" cellspacing="0" >
 
 
 
<tr colspan=2><td><b>Способ доставки<b></td></tr>
<tr ><th style="width:50%"> Метод доставки</th>
<td width=100%><input class="simple" type="radio" name="dostavka" value="samov" onChange="seldost('samovivoz')" />&nbsp;Самовывоз<br />
<input name="dostavka" type="radio" value="dost_msk" onChange="seldost('dost_msk')" checked/>Доставка<br />
<input name="dostavka" type="radio" value="dost_reg" onChange="seldost('dost_rg' )" />Доставка по регионам<br /></td></tr>
 
 
<tr id="samov" style="display: none;"><th >Названия полей для самовывоза</th><td >
<select name="city" class="impt" style="width:98.5%;">
 
<option value="1" > Москва</option>
 
</select></td></tr>
 
<tr id="dost_mosobl" ><th >Область</th><td >
<select name="city" class="impt" style="width:98.5%;"><option > Москва и область</option></select></td>
</tr>
<tr id="dost_reg" style="display: none;"><th>Область</th><td >
<select name="city" class="impt" style="width:98.5%;"><option rel="4312" value="Московская обл.">Московская обл.</option><option value="Алтайский край" >Алтайский край</option></select></td>
</tr>
<tr id="city" ><th >Город</th><td ><input type="text" name="city" id="textfield"></td>
</tr>
<tr id="index" ><th >Почтовый индекс</th><td ><input type="text" name="index" id="textfield"></td></tr>
<tr id="street" ><th >Улица</th><td ><input type="text" name="street" id="textfield"></td></tr>
<tr id="house" style="display: "><th >Дом</th><td ><input type="text" name="house" id="textfield"></td></tr>
<tr id="building" style="display: "><th >Корпус</th><td ><input type="text" name="building" id="textfield"></td></tr>
<tr id="flat" ><th >Квартира/Офис</th><td ><input type="text" name="flat" id="textfield"></td></tr>
 
 
 
<tr style="display: " > <th style="width:50%">Комментарий к заказу:</th>
<td width=100%> <textarea cols="" rows="5" class="simple impt" name="comment"></textarea></td>
</tr>
</table></div>
 
 
</form>
 
</body>

Подскажите, как сделать так, чтобы заработало в IE?

Добавлено через 3 часа 17 минут
надо было заменить onChange на onClick
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.04.2011, 14:45
Ответы с готовыми решениями:

Представитель Microsoft: «Моя работа — уничтожить IE6»
Человек, отвечающий за Internet Explorer в Microsoft, сказал в интервью изданию PC Pro, что в его задачу входит уничтожение 6 версии этого...

Работа с файлом (корректный код, некорректная работа программы)
Для записи и чтения файла использую разные функции. По одиночке они работают нормально. Вставляю их прототипы в функцию main() и нижняя...

Работа с INI: некорректная работа пользовательской функции
Ранее нашел код для работы с ini-файлами: public class INI { /// &lt;summary&gt; /// Чтение...

2
 Аватар для StagnantIce
125 / 105 / 40
Регистрация: 06.03.2011
Сообщений: 334
10.04.2011, 19:58
Лучший ответ Сообщение было отмечено как решение

Решение

вам определенно нужна функция, чтобы немного код убавить.
JavaScript
1
2
3
function display(id, display) {
  document.getElementById(id).style.display = display;
}
а лучше расписать все display

JavaScript
1
2
3
function hide(id) {
  document.getElementById(id).style.display = 'none';
}
код будет выглядеть намного лучше и меньше.

JavaScript
1
2
var r = ['city', 'index', 'street'];
for (i=0;i<r.length;i++) hide(r[i]);
0
McS
15.04.2011, 17:23
Спасибо большое за совет, код уменьшился с 80 до 50 строк.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.04.2011, 17:23
Помогаю со студенческими работами здесь

Некорректная работа
Type TArray = array of integer; function MultiplicationMatrix(Matrix1k, Matrix2k: TArray): TArray; Var i, j, index:...

Некорректная работа
Не могу разобраться в чём ошибка,пользователь вводит имя,и ссайт должен его поприветствовать,но вместо этого выводитсяя фигня hiUser.html...

Некорректная работа
Почему когда ввожу численные значения (1.2.3.4) все столбцы ровные и все корректно отображается ,но когда ввожу хоть одну букву ,то все...

Некорректная работа
Здравствуйте. Есть триггер который удаляет запись и сохраняет ее в другую таблицу.(из таблицы билет в таблицу архив) Но если зайти в...

Некорректная работа
Подскажите пожалуйста. Поставил win10, как-то сразу криво пошла установка anaconda. Запуск только через bat .... теперь выполняю...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Old Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru