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