本文实例讲述了javascript实现单击和双击并存的方法。分享给大家供大家参考。具体分析如下:
在我们进行网页开发的过程中经常会遇到这么一个问题,为一个链接注册双击事件,或者让一个按钮或者其他元素上面同时注册单击或者双击事件,这时候我们发现网页中的双击事件似乎永远都不会起作用,原因是当我们点击一次的时候,就被超链接或者单击事件截获了,本文描述了一个如何解决这个技术问题的具体方法。本解决方案的实现原理是,单击事件和双击事件都调用同一个方法,我们根据两次鼠标点击的间隔时间来判断到底是单击还是双击事件。单击事件来临的时候先不调用,等一小段时间,过了这段时间,如果没有下一次单击来临就开始调用单击对应的操作,如果有下一次点击就调用双击。 
详细描述请参加下面代码清单:
复制代码 代码如下:<HTML> 
  <HEAD> 
  <TITLE> javascript 实现单击和双击并存 </TITLE> 
  <META NAME=" Generator" CONTENT=" EditPlus" > 
  <META NAME=" Author" CONTENT=" https://www.jb51.net/" > 
  <META NAME=" Keywords" CONTENT=" " > 
  <META NAME=" Description" CONTENT=" " > 
  </HEAD>
  <BODY> 
  <SCRIPT LANGUAGE=" JavaScript" > 
  <!--
  var dcTime=250;       // doubleclick time
  var dcDelay=100;     // no clicks after doubleclick
  var dcAt=0;               // time of doubleclick
  var savEvent=null; // save Event for handling doClick().
  var savEvtTime=0;   // save time of click event.
  var savTO=null;       // handle of click setTimeOut
  
  function showMe(txt) { 
    document.forms[0].elements[0].value += txt; 
  } 
  
  function handleWisely(which) { 
    switch (which) { 
        case " click" :            
            savEvent = which; 
            d = new Date(); 
            savEvtTime = d.getTime(); 
            savTO = setTimeout(" doClick(savEvent)" , dcTime); 
            break; 
        case " dblclick" :
            doDoubleClick(which); 
            break; 
        default:
    } 
  } 
  
  function doClick(which) { 
    if (savEvtTime - dcAt <= 0) { 
        return false; 
    } 
    showMe(" 单击" ); 
  } 
  
  function doDoubleClick(which) { 
    var d = new Date(); 
    dcAt = d.getTime(); 
    if (savTO != null) { 
        savTO = null; 
    } 
    showMe(" 双击" ); 
  }
  //--> 
  </SCRIPT>
<p> 
            <a href=" javascript:void(0)" 
                onclick=" handleWisely(event.type)" 
                ondblclick=" handleWisely(event.type)" 
                style=" color: blue; font-family: arial; cursor: hand" > 
          点击一下看看结果:
      </a> 
      </p> 
        
      <form> 
          <table> 
              <tr> 
                  <td valign=" top" > 
                    事件模式: <textarea rows=" 4" cols=" 60" wrap=" soft" > </textarea> 
                  </td> 
              </tr> 
              <tr>
                  <td valign=" top" > 
                      <input type=" Reset" > 
                  </td> 
              </tr> 
          </table> 
      </form> 
  </BODY> 
</HTML>
希望本文所述对大家的javascript程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?