通过POST方法提交表单后,为什么Ajax在移动设备上刷新页面?

时间:2018-08-27 13:05:34

标签: javascript jquery html django

我正在尝试在Django网站上提交表单。 Ajax对于桌面上的表单提交工作正常,并且在提交时不刷新页面,而在移动设备上使用时,POST数据已成功提交,但页面在请求后刷新。 提交后如何防止刷新?

<script>
        $(document).ready(function(){
              $('#email_button_secondary_submit').on('click', function(e){
                $('#email_button_secondary_submit > span').removeClass('glyphicon glyphicon-chevron-right');
                $('#email_button_secondary_submit > span').addClass('fa fa-spinner fa-spin');
                $emailaddress = $('#email').val();
              $.ajax({
                type: "POST",
                url : '',
                cached: false,
                data: {
                    email: $emailaddress,
                    csrfmiddlewaretoken: $('input[name=csrfmiddlewaretoken]').val()
                },
                success: function () {
                    $('.Subscribe').hide();
                    $('.Thanks').show();
                },
                complete: function () {
                    $('#email_button_secondary_submit > span').removeClass('fa fa-spinner fa-spin');
                    $('#email_button_secondary_submit > span').addClass('glyphicon glyphicon-ok');
                },
                error: function () {
                    $('.Subscribe').hide();
                    $('.Error').show();
                    $('#email_button_secondary_submit > span').removeClass('glyphicon glyphicon-ok');
                    $('#email_button_secondary_submit > span').addClass('glyphicon glyphicon-remove');
                },
              });
              e.preventDefault();
            });
          });
    </script> 

编辑1: 我检测到on click块无法在移动设备上执行。(我注意到,在此之后添加了alert() $('#email_button_secondary_submit').on('click', function(e){

1 个答案:

答案 0 :(得分:2)

注意“功能(e)”中的“ e”。您应该添加。同时使您的“ e.preventDefault();”就像我在下面看到的一样。

<script>
    $(document).ready(function(){
          $('#email_button_secondary_submit').on('click', function(e){
            e.preventDefault();
            $('#email_button_secondary_submit > span').removeClass('glyphicon glyphicon-chevron-right');
            $('#email_button_secondary_submit > span').addClass('fa fa-spinner fa-spin');
            $emailaddress = $('#email').val();
          $.ajax({
            type: "POST",
            url : '',
            cached: false,
            data: {
                email: $emailaddress,
                csrfmiddlewaretoken: $('input[name=csrfmiddlewaretoken]').val()
            },
            success: function () {
                $('.Subscribe').hide();
                $('.Thanks').show();
            },
            complete: function () {
                $('#email_button_secondary_submit > span').removeClass('fa fa-spinner fa-spin');
                $('#email_button_secondary_submit > span').addClass('glyphicon glyphicon-ok');
            },
            error: function () {
                $('.Subscribe').hide();
                $('.Error').show();
                $('#email_button_secondary_submit > span').removeClass('glyphicon glyphicon-ok');
                $('#email_button_secondary_submit > span').addClass('glyphicon glyphicon-remove');
            },
          });
        });
      });
</script>