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

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

10.04.2011, 14:45. Показов 1382. Ответов 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
Ответ Создать тему
Новые блоги и статьи
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru