由于需要在代码中根据实际需要动态修改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、回复次数:13Top
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>Top
2 楼runmin()回复于 2002-11-29 09:47:03 得分 0 <body οnlοad="alert()"> </body> <script> document.body.onload = ""; </script> 如果没有alert改变就成功。Top
3 楼runmin()回复于 2002-11-29 09:50:25 得分 50<body οnlοad="alert()"> </body> <script> document.body.onload = Function("alert('changed')"); </script>Top
4 楼Lostinet(每晚 8:00 见)回复于 2002-11-29 09:54:06 得分 50<body> </body> <script> 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); } } </script>Top
5 楼emu(月亮不在手指尖上)回复于 2002-11-29 10:00:26 得分 50带参数的可以这么写(IE5下面通过): <span id=aa>asdfghjkl</span><br> <input type=button value=click οnclick=cc()> <script language=javascript> function cc() { document.all.aa.attachEvent("onclick",new Function("alert('ok')")); } </script>Top
6 楼meizz(梅花雪)回复于 2002-11-29 10:04:32 得分 50还有一种很好的办法就是你在函数里直接定义某个控件的某个事件. <span id=aa>asdfghjkl</span> <script language=javascript> function document.all.aa.onclick() { alert("这已经是重新定义过后的函数!"); } </script>Top
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> <script> function bb(){alert("first");} function cc(){alert("changed");} </script>Top
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));这句有可能不行,因为带参数的我从来没有调试通过。 Top
9 楼walkingpoison(walkingpoison)回复于 2002-11-29 10:34:36 得分 0 wangxj0600(旁观拍手笑疏狂,疏又何妨,狂又何妨)你可以试一下带有参数的情况,代码会略有不同的。 经过测试,我上面提到的第4种方法可以改进为setAttribute("onclick",Function("funcA(argA,argB)"),0)。 我想主要问题还是在这个Function上面吧,通过转换就可以正常使用了。Top
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方法仍然不可用。还有待探讨。
