A标签/按钮防止重复提交&页面Loading制作

【实现原理】

防止重复提交与页面的提交时的Loading设置,均是在提交,但是尚未处理完成进行的操作,且提交为异步提交(同步提交不需要考虑)。因此,其实现原理是在点击按钮或A标签时,将按钮/A标签置为不可用,在提交完成的回调函数中再将按钮/A标签置为可用;Loading原理是在点击提交时,生成Loading样式,在提交完成之后隐藏该样式。

[同步]:提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事 
[异步]:请求通过事件触发->服务器处理(这是浏览器仍然可以作其他事情)->处理完毕

【按钮防止重复提交】

function save(){
    $(‘#submit‘).attr("disabled",true);
    //或者$(‘#submit‘).attr("disabled","disabled");
    $.post(url, params, function (data) {
        $(‘#submit‘).attr("disabled",false);
        //或者$(‘#submit‘).removeAttr("disabled");
        //或者$(‘#submit‘).attr("disabled","");
    });
}

OS:原生Js处理:document.getElementById("submit").disabled = true;

【A标签防止重复提交】

需注意的是,A标签是没有disabled属性的,所以用按钮的方法控制A标签的提交是不起作用的。

//全局变量
var save_flag = true;

function save(){
    save_flag = false;
    $.post(url, params, function (data) {
        save_flag = true;
        //........其余代码
    });
}

这种方法在按钮的防止提交中也可以使用,总的来说是一种通用、简易的方法。

【Loading】

CSS中:

<style>
            #loading {
                position: fixed;
                width:500px;
                top:50%;
                left:50%;
                margin: -25px -250px;
                background-color:#FFFFFF;
                border:1px solid #CCCCCC;
                text-align:center;
                padding:25px;
            }
</style>

HTML中:

<div id="loading" style="display: none" ><img style="vertical-align: middle;" src="images/loading.gif" />Loading...</div>

JS代码:

function save(){
    $("#loading").css("display","");
    $.post(url, params, function (data) {
        $("#loading").css("display","none");
        //........其余代码
    });
}

转载请注明出处:

http://www.cnblogs.com/llicat/

时间: 2024-08-30 03:15:07

A标签/按钮防止重复提交&页面Loading制作的相关文章

利用struts2&lt;s:token&gt;标签防止用户重复提交

当用户填写完表单后,在提交过一次后,若用户做如下操作比如再次点击提交.刷新页面.提交页面呈现后点击后退按钮,都会导致表单重复提交.如果信息需要存储到后台数据库中,重复提交就会再次向数据库中插入用户信息,显然这样是不对的.解决方式有两种 (一)Session Token机制 当用户首次访问包含表单的页面时,此时服务器会做三件事 1)创建一个session对象, 2)通过解析<s:token>标签(编程时此标签在要加入表单页面中)会产生一个随机数(可以将其称为盾牌,注意这个不是session ID

// 禁用按钮防止重复提交

$(function(){ $('form input[type=button]').click(function(){ var cityval=$('form input[name=city]').val(); $.ajax({ type:'POST', url:'http://baike.baidu.com/api/openapi/BaikeLemmaCardApi?scope=103&format=json&appid=379020&bk_key='+cityval+'&am

button按钮防重复提交(点击提交之后提交按钮变灰,操作执行完之后恢复)

jsp中form表单: <form action="" id="form"> <table style="width:80%;height:80%;" border="1" cellspacing="0" cellpadding="0" align="center" valign="middle"> <tr> &

struts2 文件的上传下载 表单的重复提交 自定义拦截器

文件上传中表单的准备 要想使用 HTML 表单上传一个或多个文件 须把 HTML 表单的 enctype 属性设置为 multipart/form-data 须把 HTML 表单的method 属性设置为 post 需添加 <input type=“file”> 字段. Struts 对文件上传的支持 在 Struts 应用程序里, FileUpload 拦截器和 Jakarta Commons FileUpload 组件可以完成文件的上传. 步骤:1. 在 Jsp 页面的文件上传表单里使用

Struts2中解决表单重复提交

3. 表单的重复提交问题 1). 什么是表单的重复提交 > 在不刷新表单页面的前提下:  >> 多次点击提交按钮 >> 已经提交成功, 按 "回退" 之后, 再点击 "提交按钮". >> 在控制器响应页面的形式为转发情况下,若已经提交成功, 然后点击 "刷新(F5)" > 注意: >> 若刷新表单页面, 再提交表单不算重复提交 >> 若使用的是 redirect 的响应类型,

[原创]java WEB学习笔记73:Struts2 学习之路-- strut2中防止表单重复提交

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

Struts防止表单重复提交

1.什么是表单重复提交 > 在不刷新表单页面的前提下:         >> 多次点击提交按钮        >> 已经提交成功, 按 "回退" 之后, 再点击 "提交按钮".        >> 在控制器响应页面的形式为转发情况下,若已经提交成功, 然后点击 "刷新(F5)" > 注意:        >> 若刷新表单页面, 再提交表单不算重复提交        >> 若使

表单重复提交

一:使用JavaScript来防止表单重复提交 有三种场景:1:在网络延迟的情况下让用户有时间点击多次submit导致重复提交 2:表单提交后点击“刷新”按钮导致重复提交 3:提交后,点击浏览器的后退然后再次提交 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%><html>  <head>    <title>F

防重复提交实现方案

在WEB系统操作中,往往会出现用户连续重复点击一个按钮导致重复提交,后台程序的同一个接口代码往往上一个请求还没执行完,下一个请求就到达了,而这两个请求又是请求和操作的同一条数据,就会出现业务上的逻辑错误,往往结果不可预料: 要解决重复提交带来的问题的解决方案有多种,不如网上有很多介绍怎么通过前端页面控制来解决重复提交,当然还有其他方式,这里我采用了通过后台程序代码利用redis做分布式锁的方式来防止重复提交,其思路就是在进入一个后端接口执行前先获取一个分布式锁,如果获取成功则上锁,然后执行业务代