应用情景 经典使用情景:js的一些事件,比如:onresize、scroll、mousemove、mousehover等; 还比如:手抖、手误、服务器没有响应之前的重复点击; 这些都是没有意义的,重复的无效的操作...,设置对整个系统的影响还可能是致命的,所以我们要对重复点击的事件进行相应的处理!...节流函数 所谓的节流函数顾名思义,就是某个时刻限制函数的重复调用。 同样节流函数也是为了解决函数重复提交的问题,而防止重复提交的方法,不止节流函数一种实现。...方法汇总 本文整理了我在工作实践当中,觉的防止js重复提交,比较好用的方法,在这里和大家分享一下。...图层防止多次点击 具体实现 一、setTimeout + clearTimeout(节流函数) 方式一:闭包节流函数(可传递多个参数) /** * 闭包节流函数方法(可传参数) * @param Function
在Web开发中,对于处理表单重复提交是经常要面对的事情。那么,存在哪些场景会导致表单重复提交呢?表单重复提交会带来什么问题?有哪些方法可以避免表单重复提交? ?...显然,从演示结果来看,如果出现表单重复提交,将会导致相同的数据被重复插入到数据库中。实际上,这是不应该发生的。 如何避免重复提交表单 关于解决表单重复提交,分为在前端拦截和服务端拦截2种方式。...但是,是否需要这样做,需要考虑用户的操作体验是不是可以接受。 在前端拦截虽然可以解决场景一的表单重复提交问题,但是针对场景二(刷新)和场景三(后退重新提交)的表单重复提交是无能为力的。 ?...显然,通过在服务端保存token的方式拦截场景二和场景三的表单重复提交是非常有效的。而且,这种方式同样可以拦截场景一的表单重复提交。 ?...另外,有意思的是:在最新的Firefox浏览版本(Firefox Quantum 59.0.1 64位)中,浏览器自己就能处理场景一的表单重复提交(但是不能处理场景二和场景三的表单重复提交)。
所以,你必须保证你的软件足够地健壮,尽可能地考虑各种用例,增加限制,抵御使用者的摧残。 对于如何处理重复提交,一般教科书上都有点明,不外乎是在js代码中增加限制或者通过session来处理。...关于js代码限制,就是当用户第一次提交后,将提交按钮设置为“disable”状态,或者直接不提交重复请求,这只能处理用户重复连续点击的情况,如果用户刷新页面后再次提交,这种方法就无济于事了,因此我们更多的是通过...但是在多服务器多用户的场景下,以上方法也都会失效,在多服务器场景下,session存在于每台服务器中,请求是通过负载均衡机制分配到各台服务器上的,要通过session防止重复提交,必须有一套定向分派请求或者...世界上很多道理都是相通的,古人常将齐家治国联系在一起,你在齐家过程中得出的一些经验一定程度上可以用于治国领域,同样,处理多线程问题的一些思路方法也可以给多服务器多用户访问设计提供借鉴,处理并发问题最常用的一个方法就是加锁...这是借助redis缓存实现的类加锁机制,解决多服务器多用户场景下请求重复提交的情况。
利用同步令牌(Token)机制来解决Web应用中重复提交的问题,Struts也给出了一个参考实现。...这样如果用户回退到刚才的提交页面并再次提交的话,客户端传过来的令牌就和服务器端的令牌不一致,从而有效地防止了重复提交的发生。...具体实现可以参考TokenProcessor类中的 generateToken()方法。...1.验证事务控制令牌,会自动根据session中标识生成一个隐含input代表令牌,防止两次提交 2. 在action中: if (!...3. action有这样的一个方法生成令牌 protected String generateToken(HttpServletRequest request) { HttpSession
表单重复提交是在多用户Web应用中最常见、带来很多麻烦的一个问题。有很多的应用场景都会遇到重复提交问题,比如: 点击提交按钮两次。 点击刷新按钮。...使用浏览器后退按钮重复之前的操作,导致重复提交表单。 使用浏览器历史记录重复提交表单。 浏览器重复的HTTP请求。 几种防止表单重复提交的方法 1.禁掉提交按钮。...这种方法防止心急的用户多次点击按钮。但有个问题,如果客户端把Javascript给禁止掉,这种方法就无效了。 我之前的文章曾说过用一些jQuery插件效果不错。...这能避免用户按F5导致的重复提交,而其也不会出现浏览器表单重复提交的警告,也能消除按浏览器前进和后退按导致的同样问题。 3.在session中存放一个特殊标志。...在数据库里添加唯一约束或创建唯一索引,防止出现重复数据。这是最有效的防止重复提交数据的方法。
有位朋友,某天突然问磊哥:在 Java 中,防止重复提交最简单的方案是什么? 这句话中包含了两个关键信息,第一:防止重复提交;第二:最简单。 于是磊哥问他,是单机环境还是分布式环境?...的防重(防止重复)版本。...5.最终版——封装 以上都是方法级别的实现方案,然而在实际的业务中,我们可能有很多的方法都需要防重,那么接下来我们就来封装一个公共的方法,以供所有类使用: import org.apache.commons.collections4...; } } 小贴士:一般情况下代码写到这里就结束了,但想要更简洁也是可以实现的,你可以通过自定义注解,将业务代码写到注解中,需要调用的方法只需要写一行注解就可以防止数据重复提交了,老铁们可以自行尝试一下...总结 本文讲了防止数据重复提交的 6 种方法,首先是前端的拦截,通过隐藏和设置按钮的不可用来屏蔽正常操作下的重复提交。
jQuery中为我们提供了很多有用的方法和属性,自己总结的一些常用的函数,方法。个人认为在www.21kaiyun.com的紫微斗数星座在线排盘开发中会比较常用的,仅供大家学习和参考。...通过使用这个方法,可以在DOM载入就绪能够读取并操纵时立即调用你所绑定的函数,而99.99%的JavaScript函数都需要在那一刻执行。...这个函数是找出正在处理的元素的后代元素的好方法。...这也是Jquery操作Ajax最常用最有效的方法。...小结:在实际的开发中我们可能会发现21世纪开运网用到其他的方法和属性,以上只是个人认为新手初学jQuery时,必须掌握的一些方法。仅供大家学习的参考。有什么不对的高手指教。
表单提交时候我们应该控制提交按钮,不能点击多次进行数据的重复提交。要不然就会有冗余的重复的数据在系统中,造成系统出现数据垃圾。...jQuery很简单的就可以实现对表单提交按钮控制,下面就是相关的例子和代码。 [html] view plain copy print ?...("$('#submit').removeAttr('disabled')",3000); //设置三秒后提交按钮 显示 }) 附:其他的实现方法...后台代码控制表单提交有一个好的办法就是使用session, 具体可以参考下面这篇博文: JavaWeb学习总结(十三)——使用Session防止表单重复提交 http://www.cnblogs.com...在页面中添加Token防止越权访问-也可做表单重复提交,使用的原理也是Token!
总结: * jQuery中添加自定义或函数方法1,如 $.fn.extend({'aa':function(){}}) 或 jQuery.fn.aa=function(){}, 这种调用时就得这样,$(..."#**").aa() *jQuery中添加自定义或函数方法2,如$.extend({'aa':function(){}}),这种调用时就是这样$.aa() * jQuery中添加自定义或函数方法3,(...只是在前2种方法的基础上添加了参数处理,严格来说不算一种jQuery 自定义方法)如: $.myFuncThree("www.baidu.com",'hello',myFuncThreeCB...*/ jQuery.fn.myFuncOne=function(){ alert("我的自定义jquery方法1"); } jQuery.fn.extend...*/ jQuery.extend({ 'myFuncTwo':function(){ alert("我的自定义jquery方法2"
导语:随着接触的项目增加,很多项目都是遇到同样的问题,而每次都是使用一贯的手法进行处理。有时候有些方法并不是那么的优雅甚至有些冗余,所以自己也想开始尝试不同的方法去解决同样的问题。...false; // load.close(); }) }, }, } 这种办法简单粗暴,但是每次需要防止重复点击的地方...进行创建组件的方法,开始了自己的尝试之路。...防抖方法是一个很好限制重复事件频繁触发的,经常用在scroll、resize事件上,也可以尝试用在重复点击上面。...但是如果点击事件后需要有异步处理,单单使用防抖方法也会没办法限制弱网(PS:吐槽一下成都地铁上移动经常网络不好)下重复点击的情况。
这样确实可以避免重复引入 Student 类,但此方式并不适用于所有“重复引入”的场景。 C++ 多文件编程中,处理“多次 #include 导致重复引入”问题的方式有以下 3 种。...,所以不会再重复执行“头文件内容”部分的代码。...我们知道,#ifndef 是通过定义独一无二的宏来避免重复引入的,这意味着每次引入头文件都要进行识别,所以效率不高。...事实上,无论是 C 语言还是 C++,为防止用户重复引入系统库文件,几乎所有库文件中都采用了以上 3 种结构中的一种,这也是为什么重复引入系统库文件编译器也不会报错的原因。...总结 本节介绍了 3 种避免头文件被重复引入的方法,其中 #pragma once 和 _Pragma("once") 可算作一类,其特点是编译效率高,但可移植性差(编译器不支持,会发出警告,但不会中断程序的执行
1. jQuery核心函数 1.1 jQuery([selector,[context]]) jQuery([selector,[context]]) 接收一个包含 CSS 选择器的字符串,然后用这个字符串去匹配一组元素...("body"); //动态创建一个 div 元素(以及其中的所有内容),并将它追加到 body 元素中 1.3 jQuery(callback) 允许你绑定一个在 DOM 文档载入完成后执行的函数。...2 // 文档就绪 3}); 2. jQuery对象 在 JQuery 库中,可以通过本身自带的方法获取页面 DOM 元素的对象叫做 JQuery 对象。对象用 var 开头定义。...1var tDiv = $(“#divTmp”) //使用JQ获取元素后,就是JQuery对象了 3. jQuery静态方法 3.1 静态方法 · 静态方法对应的是对象方法,对象方法用实例对象调用,而静态方法用类名调用...(); // 实例方法必须用类的实例对象调用 13 } 3.2 jQuery.holdReady(hold) 暂停或恢复.ready() 事件的执行。
一、表单重复提交的常见应用场景 网络延迟的情况下用户多次点击submit按钮导致表单重复提交 用户提交表单后,点击【刷新】按钮导致表单重复提交(点击浏览器的刷新按钮,就是把浏览器上次做的事情再做一次,因为这样也会导致表单重复提交...) 用户提交表单后,点击浏览器的【后退】按钮回退到表单页面后进行再次提交 二、防止防止表单重复提交的方式 1、利用JavaScript防止表单重复提交 (1)、用JavaScript控制Form表单只能提交一次...(5)、提交后重定向到一个提交成功的页面 表单提交后跳转到另外一个成功页面。这样可以避免用户按F5导致的重复提交,浏览器也不会出现表单重复提交的警告,以及消除按浏览器前进和后退按导致的同样问题。...如果相等代表首次提交,此时将session或者缓存中保存的token值remove掉,反之则认为重复提交,服务端不予处理。...如果表单重复提交,那么数据库插入重复记录时,唯一约束能有效避免重复入库。
jQuery核心函数 jQuery的核心函数就是$();,圆括号内可以传递函数、字符串选择器、字符串代码片段、DOM元素等。...传递函数 $(function () { alert(1) }) 字符串选择器返回一个jQuery对象,对象中保存了找到的DOM元素 $(function () { var $box1...jQuery中的each静态方法和map静态方法的区别 each静态方法默认的返回值就是遍历谁就返回谁,而map静态方法默认的返回值就是一个空数组 ?...each静态方法不支持在回调函数中对遍历的数组进行处理,map静态方法可以在回调函数中通过return对遍历的数组进行处理 ?...var res = $.isFunction(fn) jQuery的本质上就是一个函数。 暂停ready的执行 默认情况下当页面加载完毕,JQuery的ready入口函数将会自动执行。.
get方法获取指定index的DOM对象,也就是我们说的jQuery对象转DOM对象。...二、jquery对象的方法 1、.each( function(index, Element) ) //each的参数顺序和js的参数顺序相反 遍历一个jQuery对象,为每个匹配元素执行一个函数 $(...'li').each(function(ind,e){ console.log(('ind+':'+$(e).text()') } //text方法是取出jquery对象的值, jQuery对象里面回调函数...,一般来说对应的元素都是原生dom,要执行jQuery的text方法需要加$转换成jquery对象 2、jQuery.each( collection, callback(indexInArray, valueOfElement...传递处理函数给.ready()方法,能保证DOM准备好后就执行这个函数,因此,这里是进行所有其它事件绑定及运行其它 jQuery 代码的最佳地方。
WordPress代码实现防止发表重复标题的文章,如果对你有帮助就看看吧。其实所有的插件这些的就等于放到function.php的代码片段。...直接看代码把:/** * 发表文章时禁止与已存在的标题相重复 * Modify from Plugin: Duplicate Title Validate * Description: this plugin...>jQuery(function($){ function checkTitleAjax(title, id,post_type) { var data = {..._('恭喜,此标题未与其他文章标题重复!' , '').'...php _e('貌似已经存在相同标题的文章,若您使用了文章别名作为固定链接,则可以通过修改本文的固定链接来使标题不再重复!' , '') ?> <?
Google的CDN中加载jQuery库。...确保将其放在标签或页面内容的顶部。二、基本语法 jQuery使用CSS选择器来选择HTML元素,并提供了一组方法来操作所选元素。...基本语法如下:$(selector).method();其中,$符号是jQuery的别名,用于访问jQuery库中的函数和方法。...selector是要选择的HTML元素,而method()则是要对选择的元素执行的方法。三、选择器 jQuery的选择器功能类似于CSS选择器,可以根据元素的ID、类名、标签名、属性等进行选择。...四、常用方法 jQuery提供了许多常用的方法,用于对选择的元素进行操作。CSS方法 使用css()方法可以设置或获取元素的CSS属性。
jQuery提供了一个animate函数,可以通过改变CSS属性来实现一些动画效果。...Complete Function 完成后的函数动作 如果指定,complete 回调函数会在动画执行完毕后被触发。这在设计多个顺序发生的动画时特别有用。...Step Function 步长函数 在animate的第二种调用方式中提供了一个step的选项,这是一个回调函数,可以在每一个step执行时被触发。...利用jQuery的Animate函数和Effect插件,做了一个类似于IBM首页的焦点图切换效果,可以参考 https://github.com/cocowool/RoseFocus 参考资料: 1...、animate of jQuery 2、jQuery的Index方法 3、jQuery UI effect
我实现点击table表格中的删除按钮,找到当前按钮的祖先元素tr 然后删除该行,但是我首先点击删除的时候要先弹出提示框,是否要下载,这时在点击删除按钮删除,之前没有考虑到事件重复绑定问题,所以每次点击删除的时候就会多选择几行...,之后选择的越来越多,经过网友解答,成功解决,先把重复绑定的删除的click事件解绑再继续绑定,就没问题。