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

После отправки формы перезагружается страница и функция не работает

23.11.2016, 16:03. Показов 5220. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
После отправки формы перезагружается страница и функция не срабатывает. Подскажите в чем ошибка)

Задание звучит следующим образом:
Создайте хтмл файл с формой с двумя текстовыми полями и одной кнопкой с надписью "Сравнить числа", где пользователь вводит 2 числа, нажимает на кнопку (привяжите к кнопке onclick = "назва_вашои_функции ()"), и снизу выводится, какое из них больше, а какое - меньше. Чтобы получить значение элемента текстового поля, воспользуйтесь document.getElementById ( "...") .value - вернет значение, которое вы ввели. Скрипт должен состоять из функции.

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<!DOCTYPE html>
<html>
<head>
  <meta charset='utf-8'>
  <title>Лаба №1</title>
  <link href='css/normalize.css' rel='stylesheet'>
  <link href='css/main.css' rel='stylesheet'>
</head>
<body>
 
  <h1>Задание №1</h1>
  <form>
    <input type='text' id='fieldOne' maxlength='1000000' placeholder='Введите первое число'>
    <input type='text' id='fieldTwo' maxlength='1000000' placeholder='Введите второе число'>
    <input type='submit' onclick='compareNumbers()' value='Сравнить!'>
  </form>
  
 <script src='js/taskOne.js' type='text/javascript'></script> 
</body>
</html>

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
  var numOne = document.getElementById('fieldOne');
  var numTwo = document.getElementById('fieldTwo');
 
function compareNumbers(numOne, numTwo) {
  if (numOne > numTwo) {
    document.write('<p>Число ' + numOne + ' больше чем ' + numTwo + '</p>');
  } else if (numOne < numTwo) {
    document.write('<p>Число ' + numOne + ' меньше чем ' + numTwo + '</p>');
  } else if (numOne = numTwo) {
    document.write('<p>Числа равны!</p>');
  }
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.11.2016, 16:03
Ответы с готовыми решениями:

Всплывающее окно после отправки на почту (перезагружается страница)
Всем привет, делал сайт , по заданию нужно нужно сделать всплывающее окно &quot;Сообщение отправлено&quot; , я делал по принципу замены css...

Не работает JQ после отправки формы
Доброго времени суток! Я начинаю осваивать JQ и появилась такая проблема - у меня есть страница(site/kabi), а на странице форма. Когда я...

Страница обновляется после отправки файла на сервер
Помогите решить проблему и упростить код. В общем, суть проблемы - при загрузке файла на сервер - обновляется страница, пробовал и...

4
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
23.11.2016, 18:46
Цитата Сообщение от John_cher Посмотреть сообщение
Подскажите в чем ошибка)
В использовании document.write.
0
 Аватар для vettel
84 / 84 / 41
Регистрация: 14.02.2015
Сообщений: 320
23.11.2016, 20:14
John_cher,
1) У вас же в методичке черным по белому написано:
Цитата Сообщение от John_cher Посмотреть сообщение
воспользуйтесь document.getElementById ( "...") .value
value! понимаете? А это что?
JavaScript
1
2
var numOne = document.getElementById('fieldOne');
var numTwo = document.getElementById('fieldTwo');
У вас в переменных в итоге не value (числа), а DOM-объекты.

2) Главная ошибка и суть проблемы - в юзании input type="submit". По клику он отправляет вашу форму. Юзайте другой тип, скажем button.
Ну и не используйте document.write().
1
супермизантроп
Эксперт JS
3941 / 2979 / 692
Регистрация: 18.04.2012
Сообщений: 8,629
23.11.2016, 20:31
John_cher, кроме ненужного использования кнопки сабмита (о чём выше вам указал коллега vettel, вы допустили ещё одну ошибку, а именно:
метод document.write () можно (и нужно!) использовать только в процессе формирования документа -- тогда он ДОписывает на страницу то, что у этого метода указано в круглых скобках
а вот когда документ уже сформирован (т.е. когда браузер либо прочитывает имеющиеся в коде теги </body> и </html>, либо сам добавляет их в конец кода), метод document.write () полностью ПЕРЕписывает сформированный документ

ваш документ полностью сформирован и ожидает действий пользователя (нажатие на кнопку) : в этом случае НЕ НАДО использовать метод document.write () --
1
0 / 0 / 0
Регистрация: 19.11.2016
Сообщений: 10
24.11.2016, 22:55  [ТС]
Добрый день, попробовала изменить по советам (не сильно разбираюсь в языке), получалися такой код, но тоже не работает)

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<!DOCTYPE html> 
<html> 
<head> 
<meta charset='utf-8'> 
<title>Лаба №1</title> 
<link href='css/normalize.css' rel='stylesheet'> 
<link href='css/main.css' rel='stylesheet'> 
</head> 
<body> 
 
<h1>Задание №1</h1> 
<form> 
<input type='text' id='fieldOne' maxlength='1000000' placeholder='Введите первое число'> 
<input type='text' id='fieldTwo' maxlength='1000000' placeholder='Введите второе число'> 
<button type='submit' onclick='compareNumbers()'>Сравнить!</button> 
</form> 
<div id='output'> 
 
</div> 
<script src='js/taskOne.js' type='text/javascript'></script> 
</body> 
</html>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
function compareNumbers() { 
var numOne = document.getElementById('fieldOne').value; 
var numTwo = document.getElementById('fieldTwo').value; 
//var result = document.getElementById('output').innerHTML; 
if (numOne > numTwo) { 
document.getElementById('output').innerHTML = ('<p>Число ' + numOne + ' больше чем ' + numTwo + '</p>'); 
} else if (numOne < numTwo) { 
document.getElementById('output').innerHTML = ('<p>Число ' + numOne + ' меньше чем ' + numTwo + '</p>'); 
} else if (numOne = numTwo) { 
document.getElementById('output').innerHTML = ('<p>Числа равны!</p>'); 
} 
}
Добавлено через 10 часов 56 минут
Все исправила, работает)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.11.2016, 22:55
Помогаю со студенческими работами здесь

Вывод модальной формы после отправки формы AJAX
Здравствуйте, помогите, пожалуйста, разобраться, есть модальная форма arcticmodal для просмотра этой формы можно найти её в поисковике, она...

Страница обновляется после отправки формы - php
На странице html добавлена форма обратной связи на php кодом &lt;?php include (&quot;index.php&quot;); ?&gt; При нажатии на отправить, сообщение...

Как сделать чтобы страница не обновлялась после отправки формы
Доброго времени суток дорогие Форумчане :) PHP знаю не очень хорошо, поэтому прошу вас выручить. Написал простой скрипт изменения цены...

При отправки формы страница просто обновляется
Доброго времени суток. Столкнулся с проблемой, когда &quot;скрипт&quot; как бы что-то делает, но в то же время не делает ничего. Если честно,...

Редирект после отправки формы
Добрый день друзья. Есть такая строчка: &lt;a href class=&quot;btn btn-danger&quot; type=&quot;submit&quot; role=&quot;button&quot;&gt;ОТПРАВИТЬ&lt;/a&gt;&lt; Как...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru