天天看点

关于onclick时间的改变

由于需要在代码中根据实际需要动态修改onclick事件的处理程序,于是我查找了一下csdn和msdn,找到了一些方法。但是试过之后发现都不起作用。  

  1.使用setAttribute方法。  

  setAttribute("onClick","funcA(argA,argB)",0)  

  结果是onClick属性确实被赋予了"funcA(argA,argB)",但是却只是一个字符串,无法运行这个函数。而我把"funcA(argA,argB)"的引号去掉以后,却又没有反应了。  

  2.使用attachEvent方法  

  attachEvent("onClick",funcA(argA,argB))  

  结果似乎并不奏效。attachEvent的第二个参数需要一个指向函数的指针,我这里函数加上了参数,结果就根本不起作用了。  

  3.迫不得已,我专门写了一个临时的函数funcB(),里面只有一条语句:funcA(argA,argB)。然后使用attachEvent("onClick",funcB),结果是仍然没有起作用——我不知道这里是否需要配合dettachEvent的使用,如果需要,我也很难得到onClick事件原先指向的函数。  

  4.我仍然使用上面的临时函数funcB(),使用setAttribute("onClick",funcB,0),结果这次成功了。  

  事情总算圆满解决了,但是仍然有很多值得思考的地方。为什么使用前面3种方法都不行呢?如果不写临时函数,能完成需要的功能吗?这些我都不是很清楚,希望各位能够给我一些指点和参考。  

  附:调试环境:win2000   pro,   ie   6.0  

问题点数:200、回复次数:13

Top

 1 楼meizz(梅花雪)回复于 2002-11-29 09:44:30 得分 0 不懂你为什么没有成功,到少我这里测试是通过的   win2k   server   IE   6.0  

  <span   id=aa>asdfghjkl</span><br>  

  <input   type=button   value=click   οnclick=cc()>  

  <script   language=javascript>  

  function   cc()  

  {  

        document.all.aa.attachEvent("onclick",bb);  

  }  

  function   bb()  

        alert("ok");  

  </script>

2 楼runmin()回复于 2002-11-29 09:47:03 得分 0 <body   οnlοad="alert()">  

  </body>  

  <script>  

  document.body.onload   =   "";  

  </script>  

  如果没有alert改变就成功。

3 楼runmin()回复于 2002-11-29 09:50:25 得分 50<body   οnlοad="alert()">  

  document.body.onload   =   Function("alert('changed')");  

4 楼Lostinet(每晚 8:00 见)回复于 2002-11-29 09:54:06 得分 50<body>  

  function   MyFunction(arg1,arg2)  

  alert(arg1+":"+arg2);  

  var   a="aa";  

  var   b="bb";  

  document.body.attachEvent("onclick",GetTheFunction(a,b));  

  a="11";  

  b="22";  

  MyFunction(a,b);  

  function   GetTheFunction(x,y)  

  return   Proxy;  

  function   Proxy()  

  return   MyFunction(x,y);  

5 楼emu(月亮不在手指尖上)回复于 2002-11-29 10:00:26 得分 50带参数的可以这么写(IE5下面通过):  

        document.all.aa.attachEvent("onclick",new   Function("alert('ok')"));  

6 楼meizz(梅花雪)回复于 2002-11-29 10:04:32 得分 50还有一种很好的办法就是你在函数里直接定义某个控件的某个事件.  

  <span   id=aa>asdfghjkl</span>  

  function   document.all.aa.onclick()  

        alert("这已经是重新定义过后的函数!");  

7 楼wangxj0600(闭门思过中)回复于 2002-11-29 10:21:34 得分 0 <button   οnclick=bb()   id=aa>dsf</button>  

  <button   οnclick="document.all.aa.οnclick=cc"   id=dd   >dsf</button>  

  function   bb(){alert("first");}  

  function   cc(){alert("changed");}  

8 楼walkingpoison(walkingpoison)回复于 2002-11-29 10:27:54 得分 0 meizz(梅花雨):我这里就是不成功的原因就是,我调用的函数是有参数的,写法跟不带参数的相同是不行的。  

  经过测试,我发现obj.attachEvent("onclick",new   Function("funcA(argA,argB)"))的方法在我这里仍然不行。  

  不过obj.οnclick=Function("funcA(argA,argB)"))的方法通过测试为可用。  

  Lostinet(迷失网络)的方法比较复杂,我还没有进行测试。但是我觉得document.body.attachEvent("onclick",GetTheFunction(a,b));这句有可能不行,因为带参数的我从来没有调试通过。  

9 楼walkingpoison(walkingpoison)回复于 2002-11-29 10:34:36 得分 0 wangxj0600(旁观拍手笑疏狂,疏又何妨,狂又何妨)你可以试一下带有参数的情况,代码会略有不同的。  

  经过测试,我上面提到的第4种方法可以改进为setAttribute("onclick",Function("funcA(argA,argB)"),0)。  

  我想主要问题还是在这个Function上面吧,通过转换就可以正常使用了。

10 楼walkingpoison(walkingpoison)回复于 2002-11-29 10:59:43 得分 0 总结:  

  在调用带参数的函数的时候,可以用两种方法  

  1.使用obj.οnclick=Function("funcA(argA,argB)"))的方法直接修改。  

  2.使用setAttribute方法,obj.setAttribute("onclick",Function("funcA(argA,argB)"),0)。  

  经过测试,attachEvent方法仍然不可用。还有待探讨。

继续阅读