js防止表单重复提交的两种方法
2023-06-13 09:15:06 时间
第一种:用flag标识,下面的代码设置checkSubmitFlg标志:
复制代码代码如下:
<scriptlanguage="”javascript”">
varcheckSubmitFlg=false;
functioncheckSubmit(){
if(checkSubmitFlg==true){returnfalse;//当表单被提交过一次后checkSubmitFlg将变为true,根据判断将无法进行提交。
}
checkSubmitFlg==true;
returntrue;
}
</script>
<formname=”form1”method=”post”onsubmit=”returncheckSubmit();”>
………..</form>
第二种:在onsubmit事件中设置,在第一次提交后使提交按钮失效,代码如下:
<formaction=”about:blank”method=”post”onsubmit=”getElementById(‘submitInput").disabled=true;returntrue;”target=”_blank”>
<inputtype=”submit”id=”submitInput”/>
</form>
</body>
</html>
</script>
因为程序源码跟WIN2000的注册表有冲突,帖子发出后会出现无效页面,以致于论坛里有很多无恶意的重复帖子,后来想出了一个办法,用JS避免重复提交,下面是部分源码:
<scriptLanguage="JavaScript">
functionformsubmit(){
Today=newDate();
varNowHour=Today.getHours();
varNowMinute=Today.getMinutes();
varNowSecond=Today.getSeconds();
varmysec=(NowHour*3600)+(NowMinute*60)+NowSecond;
if((mysec-document.formsubmitf.mypretime.value)>600)
//600只是一个时间值,就是5分钟内禁止重复提交,值随你高兴设
{
document.formsubmitf.mypretime.value=mysec;
}
else
{
alert("按一次就够了,请勿重复提交!请耐心等待!谢谢合作!");
returnfalse;
}
document.forms.formsubmitf.submit();
}
</script>
</HEAD>
<BODYBGCOLOR="#FFFFFF">
<formname=formsubmitfid="the"method="post"action="XXX.asp">
<inputtype=hiddenname="mypretime"value="0">//这句不能少,用隐含变量传递一个时间初值
//这里是你要提交的内容
<inputtype="button"value="写好了"name="button1"class="4round"onclick="formsubmit()"> <fontclass="red">(请按一次,耐心等待!)</font> <inputtype="reset"value="重写"name="button2"class="4round">
</form>
用了这个代码,论坛的重复帖子明显减少,不过有个缺点,就是刷新一次,检测就不起作用,好处就是利用JS检测,不需要额外的权限支持,至于效果如何,用不用就随你们了,(最好前端跟后端都加上检测)
相关文章
- Vue.js框架中权衡的艺术
- js的sort排序方法_sort对象排序
- 【说站】js事件委托如何理解
- js数组对象转字符串方法_数组表示
- JS判断数据类型的方法有哪些_c语言数据类型
- js有几种数据类型,基本数据类型有哪些_js中简单数据类型
- js中四舍五入的方法_JS取整
- java字符串分割split_js的sort排序方法
- JS indexOf()和lastIndexOf()方法:在数组中查找某个元素
- Highslide.js是一款基于js实现的网页中图片展示插件
- 代码精简的可以实现元素圆角的js函数
- JscallBack返回前一页的js方法
- 屏蔽Flash右键信息的js代码
- js过滤数组重复元素的方法
- js下通过prototype扩展实现indexOf的代码
- 远离JS灾难css灾难之js私有函数和css选择器作为容器
- js获取TreeView控件选中节点的Text和Value值的方法
- js获取坐标通过JS得到当前焦点(鼠标)的坐标属性
- js去除重复字符串两种实现方法
- js弹出模式对话框,并接收回传值的方法
- js控制web打印(局部打印)方法整理
- js实现广告漂浮效果的小例子
- js加载之使用DOM方法动态加载Javascript文件
- js+css实现遮罩居中弹出层(随浏览器窗口滚动条滚动)
- javascript分页代码实例分享(js分页)
- 使用JSLint提高JS代码质量方法分享
- JS删除字符串中重复字符方法
- 用js格式化金额可设置保留的小数位数
- NODE.JS加密模块CRYPTO常用方法介绍
- 浅谈JS日期(Date)处理函数
- node.js中的fs.lchownSync方法使用说明
- js自动生成的元素与页面原有元素发生堆叠的解决方法