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

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

30.03.2020, 16:14. Показов 2382. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru