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

Отменить поднятие страницы вверх при нажатии button

30.03.2020, 16:14. Показов 2366. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Приветствую.

Есть кнопка:
HTML5
1
<button type="submit" class="btn btn-info btn-xl" id="sendMessageButton">Отправить</button>
При нажатии на нее страница поднимается вверх. Как можно отменить это действие?

Обработчик:
JavaScript
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
submitSuccess: function($form, event) {
      event.preventDefault(); // prevent default submit behaviour
      // get values from FORM
      var name = $("input#name").val();
      var phone = $("input#phone").val();
      var theme = $("select#theme").val();
      var message = $("textarea#message").val();
      var firstName = name; // For Success/Failure Message
      // Check for white space in name for Success/Fail message
      if (firstName.indexOf(' ') >= 0) {
        firstName = name.split(' ').slice(0, -1).join(' ');
      }
      var btnEnabled = $this = $("#sendMessageButton").hasClass('disabled');
      //$this.prop("disabled", true); // Disable submit button until AJAX call is complete to prevent duplicate messages
      if(btnEnabled) return false;
      $.ajax({
        url: "././mail/contact_me.php",
        type: "POST",
        data: {
          name: name,
          phone: phone,
          theme: theme,
          message: message
        },
        cache: false,
        success: function() {
          // Success message
          $('#success').html("<div class='alert alert-success'>");
          $('#success > .alert-success').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>&times;")
            .append("</button>");
          $('#success > .alert-success')
            .append("<strong>Ваша заявка успешно отправлена. В течении 5 минут, Вам перезвонят по указанному номеру!</strong>");
          $('#success > .alert-success')
            .append('</div>');
          //clear all fields
          $('#contactForm').trigger("reset");
        },
        error: function() {
          // Fail message
          $('#success').html("<div class='alert alert-danger'>");
          $('#success > .alert-danger').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>&times;")
            .append("</button>");
          $('#success > .alert-danger').append($("<strong>").text("Извините, похоже, мой почтовый сервер не отвечает. Пожалуйста, попробуйте обратиться напрямую по адресу: "));
          $('#success > .alert-danger').append('</div>');
          //clear all fields
          $('#contactForm').trigger("reset");
        },
        complete: function() {
          setTimeout(function() {
            $this.prop("disabled", false); // Re-enable submit button when AJAX call is complete
          }, 1000);
        }
      });
    }
Подскажите, пожалуйста!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.03.2020, 16:14
Ответы с готовыми решениями:

Открытие страницы при нажатии на кнопку(button)
Привет Всем! Подскажите кто знает каким образом можно нажать на кнопку(button) и после этого открылся сайт к примеру 'www.yandex.ru'. ...

Поднятие вверх при всплывании модального окна
Как решить такую проблему при щелчке на ссылку появляется модальное окно &lt;a href=&quot;#join_form&quot;...

При нажатии на Button каждый раз создается новый компонент (button/label/textbox)
Как реализовать?

2
238 / 161 / 67
Регистрация: 18.06.2016
Сообщений: 509
30.03.2020, 20:39
Цитата Сообщение от halcyon Посмотреть сообщение
При нажатии на нее страница поднимается вверх
Хорошо бы подумать, что она просто начинает плавно поднимать вверх, но ведь скорее всего это просто действие браузера по умолчанию.

submitSuccess: function($form, event) {

По моему эта функция принимает один аргумент, и запись вида submitSuccess: function что-то странное на это редактор ругается

event при таком раскладе будет undefined, используется $this в теле функции в стрелочных функциях, хотя строчки $this = $(this); нету.

JavaScript
1
2
3
4
const button = document.getElementById('sendMessageButton');
console.log(button)
button.onclick = function(event) {
// ваш код, ну и дальше смотрите что консоль выдаст
0
0 / 0 / 0
Регистрация: 17.01.2019
Сообщений: 11
31.03.2020, 19:58  [ТС]
Alex Web, выводит:
HTML5
1
<button type="submit" class="btn btn-info btn-xl disabled" id="sendMessageButton">Отправить</button>
Цитата Сообщение от Alex Web Посмотреть сообщение
хотя строчки $this = $(this); нету.
После submitSuccess идет:
JavaScript
1
2
3
filter: function() {
      return $(this).is(":visible");
    },
Может быть поэтому той строчки нет.. я просто не селен в этом языке.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.03.2020, 19:58
Помогаю со студенческими работами здесь

Создание button без заднего фона, и подключение коротких звуков при нажатии button
Т.к. я только начинающий юзер C#, хотел бы спросить, если кто сможет подсказать, как убрать задний фон на баттоне, что б он вливался в фон...

Как сделать, чтобы при нажатии кнопки Push Button загоралась та или иная кнопка Radio Button
вопрос: Как сделать,чтобы при нажатие кнопки Push Botton загоралась та или иная кнопка Radio Button?

Поднятие блока при загрузке страницы
Добрый день. Есть меню с id=&quot;menu&quot; position:fixed, top:50px, нужно чтобы при загрузке страницы оно медленно поднималось вверх до top:0,...

Поднятие текста вверх блока
Прошу помочь. Хочу меню переместить вверх, не знаю как это нужно сделать. Можете дать ссылки на ресурсы, или подсказать какими тегами...

Скрипт для поднятие объявления вверх
Ребята помогите есть доска объявлений. где нужно прописать код что бы поднимать объявление раз в сутки или раз в неделю, может уже кто...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
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 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru