0 / 0 / 0
Регистрация: 19.11.2016
Сообщений: 10

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

23.11.2016, 16:03. Показов 5228. Ответов 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 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru