首页 > 解决方案 > 为什么 Ajax 在移动设备上通过 POST 方法提交表单后会刷新页面?

问题描述

我正在尝试在我的 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){

标签: javascriptjqueryhtmldjango

解决方案


注意'function(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> 

推荐阅读