Изменить кнопку отправки на загрузку изображения с помощью jquery - PullRequest
5 голосов
/ 18 июля 2011

В последнее время на многих сайтах я видел, как кнопки нажимались на загружаемые / думающие изображения после их нажатия, чтобы предотвратить двойной щелчок и убедиться, что пользователь знает, что происходит, прежде чем страница мигнет.В этом случае на самом деле ничего асинхронного не происходит - просто отправка регулярной формы.

Знаете ли вы какие-нибудь хорошие учебники, как это сделать?

Ответы [ 9 ]

10 голосов
/ 18 июля 2011

Иди самым простым путем. Скажите, что ваша кнопка btnSubmit.

<asp:Button ID="btnSubmit" runat="server" OnClick="btnSubmit_Click" Text="Submit" />
<div id="divMsg" style="display:none;">
    <img src="../images/loading.gif" alt="Please wait.." />
</div>

Теперь используя jquery, по нажатию кнопки:

<script type="text/javascript">
     $('#btnSubmit').click(function(){
         $(this).attr('disabled','disabled');
         $('#divMsg').show();
         //your client side validation here
         if(valid)
            return true;
         else
            {
              $(this).removeAttr('disabled');
              $('#divMsg').hide();     
              return false;
            }
     });
</script>

Кнопка отправки будет отключена, появится анимированное изображение loading.gif. И страница будет опубликована. Преимущество заключается в том, что в случае неудачной проверки вы можете снова включить кнопку отправки и скрыть загрузочное изображение. В таком случае, очевидно, вы увидите сообщение об ошибке.

4 голосов
/ 18 июля 2011

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

В этих случаях вы можете использовать другой метод, который работает так же хорошо - скрыть отправку и добавить изображение:

$(document).ready(function() {
    $('input[type="submit"]').click(function() {
        $(this).css('display', 'none');
        $('<img>').attr('src', 'http://www.mayla.ro/App_Themes/Glass/Editors/Loading.gif').insertAfter($(this));
    });
});
2 голосов
/ 18 июля 2011

Использование .replaceWith():

$(".submitButton").click(function () {
    $(this).replaceWith("<img src='loading.gif'>");
});
1 голос
/ 11 июля 2016

мой способ сделать это:

$(document).ready(function () {
    $('.class_name').click(function () {
        $(this).parent().append('<img src="" />');
        $(this).hide();
    });
});

кредитов: https://github.com/phpawy/jquery-submit-once

0 голосов
/ 09 января 2018

Любая из вышеперечисленных стратегий «замены» будет работать, но имейте в виду одну вещь: если вы не отправляете назад (например, веб-формы), но публикуете на другой странице (например, MVC), пользователь сможетнажмите назад.На этом этапе кнопка будет скрыта, и все, что вы увидите, это вертушка.

Я продолжал сталкиваться с этой проблемой и обнаружил, что если вы установите для атрибута unload тега BODY пустое значение "", то эта страница будет по умолчанию «возвращена» к исходному состоянию,Я предполагаю, что это очищает кэшированную версию страницы вашего браузера, поэтому он будет знать, что нужно вернуться к исходной версии, где был прятан спиннер.После того, как я добавил эту пустую выгрузку, проблема была исправлена.Я пробовал это на FF и Chrome

0 голосов
/ 11 августа 2011

Событие может быть привязано к форме как стандартная практика

<script type="text/javascript">
     $('form').submit(function(){
         $('#btnSubmit').attr('disabled','disabled');
         $('#divMsg').show();
         //your client side validation here
         if(valid)
            return true;
         else
            {
              $(this).removeAttr('disabled');
              $('#divMsg').hide();     
              return false;
            }
     });
</script>
0 голосов
/ 18 июля 2011

Это заменяет все отправленные входные данные изображением в форме

$(function() {
    $("form").submit(function() {
        $(":submit").replaceWith('<img src="/loading.gif" />');
    });
});

Вы также можете отключить отправку формы снова, если пользователь нажимает кнопку ввода в поле формы ...

$(function() {
    // only run this handler on the first submit of the form 
    $("form").one("submit", function() {
        // replace all submit inputs with an image
        $(":submit").replaceWith('<img src="/loading.gif" />');  
        // don't let this form be submitted again
        $(this).submit(function() { return false; });
    });
});
0 голосов
/ 18 июля 2011

Я думаю, что вы ищете это, кнопка имеет эту функцию updatemycartpage() в событии onclick

<script language="JavaScript">
     function updatemycartpage(index,itemId,itemnumber){

   jQuery('#Page').html('<p><center><img src="/images/ajax-loader.gif"/></center></p>');
    $.post("/cart.php", {
        'hidItemId[]' : itemId,
        'hidLineId[]' : itemnumber

    },function(data){
        document.location.href ="/cart.php";
    });
}
</script>
0 голосов
/ 18 июля 2011

Просто удалите кнопку отправки и замените ее своим изображением (сделайте это из события onclick).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...