为超链接加上disabled后的轶事_javascript技能_脚本之家

场情: 一张页面中原来有一个超链接按钮,点击后可以获取到短信认证码。如
复制代码 代码如下:
获取短信认证码)

可以设置超链接的Disabled属性的true 和 false来确定超链接是不是能点击 

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

例如: 
<a herf=” onclick=’return click(this);’
disabled=’ture’>bai du</a> 

上面的意思是不想让bai
du的超链生效,但在click不做任何约束和判断的话,但点击bai
du的时候自然就会跳转到百度页面,这就是html中超链接禁用属性的bug 
可以添加下面js约束来判断超链接是否可以使用 
    <script language=’javascript’> 
      function click(obj) 
      { 
        if(obj.disabled) 
        { 
            return false; 
        } 
        return ture; 
      } 
    </script> 

下面的微软给出的bug解决方案: 
借助了全局变量,使用别的按钮来改变disabled的属性,来得到禁用属性的效果.; 

BUG: DISABLED 属性不在禁用超链接 
尽管 DISABLED 属性设置为 True 一个超链接为在以下, 
<a DISABLED=”true” href=” do you
want to go today?</a> 
用户仍可以单击超链接,然后 Internet Explorer 导航到所选页。