作家
登录

为超链接加上disabled后的故事

作者: 来源:www.28hudong.com 2013-03-30 01:07:36 阅读 我要评论

场情:   一张页面中原来有一个超链接按钮,点击后可以获取到短信认证码。如 复制代码 代码如下: <a href="javascript:reciverSms()">获取短信认证码</a> <script type="text/javascript"> function reciverSms(){ var sms = getSmsCode(); } </script> 但是考虑到频繁点击获取认证码,对相关设备的压力,就做了一个点击5秒后才允许再点击的逻辑,于是又来了下一个版本 复制代码 代码如下: function reciverSms(obj){ var sms = getSmsCode(); obj.disabled = true; windows.setTimeout(function(){ obj.disabled = false; },5000); } 代码逻辑很简单,获取一次短信后,链接禁用5秒。可是没有想的事情又来了,原来超链接禁用了后虽然样子变成禁用了,但是还是可以点击的,原来是个陷阱,于是又来了第三个版本 复制代码 代码如下: function reciverSms(obj){ if(obj.disabled){ return; } var sms = getSmsCode(); obj.disabled = true; windows.setTimeout(function(){ obj.disabled = false; },5000); } 至此这个功能因该是算做好了,可是还有一件令我想不的事,之前说超连接disabled属性为true时,表现出来的样子是灰色不可用状态,但这里有个特例,如果这个超链接被设置了 color的css属性样式,在非ie浏览器上表现出来的样子就不是禁用了,终于看到ie的好了。于是第四个版本出现了。 复制代码 代码如下: function reciverSms(obj){ if(obj.disabled){ return; } var sms = getSmsCode(); obj.disabled = true; addClass(obj,"gray"); windows.setTimeout(function(){ obj.disabled = false; removeClass(obj,"gray"); },5000); } 通过一步步的改进,一个芝麻功能终于完成了。例子虽小,但却给了我很多思考。

  推荐阅读

  javascript处理table表格的代码

复制代码 代码如下: var picarry = {}; var lnkarry = {}; var ttlarry = {}; function FixCode(str){ return str.replace("'","="); } var t=document.getElementById("pictable"); var rl=t.rows.length; var ba>>>详细阅读


本文标题:为超链接加上disabled后的故事

地址:http://www.17bianji.com/kaifa2/JS/25253.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)