手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >为超链接加上disabled后的故事
为超链接加上disabled后的故事
摘要:场情:一张页面中原来有一个超链接按钮,点击后可以获取到短信认证码。如复制代码代码如下:获取短信认证码functionreciverSms()...

场情:

一张页面中原来有一个超链接按钮,点击后可以获取到短信认证码。如

复制代码 代码如下:

<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);

}

通过一步步的改进,一个芝麻功能终于完成了。例子虽小,但却给了我很多思考。

【为超链接加上disabled后的故事】相关文章:

javascript动态创建链接的方法

js实现鼠标移到链接文字弹出一个提示层的方法

jQuery Timelinr实现垂直水平时间轴插件(附源码下载)

JS中Eval解析JSON字符串的一个小问题

链接渐变效果

CSS+JS实现点击文字弹出定时自动关闭DIV层菜单的方法

js比较日期大小的方法

AngularJS的内置过滤器详解

不错显示时间特效

总结一些js自定义的函数

精品推荐
分类导航