一个页面使用两次timepicker.js引起的Maximum call stack size exceeded问题解决办法及bug修复
可能大多数人用过,jquery ui组件中,有个叫datepicker的,用来接收用户输入的日期,截图如下:

这个控件的缺点是不能选择时分秒,如项目中需要的输入时分秒这样的数据,就有点遗憾了。不过幸好有了下面这一款插件的出现,那就是timepicker,专门针对datepicker的这个弱点,添加了选择时分秒的功能,截图如下:

这样一来,就可以输入带有时分秒的日期时间了。
本文正题来了:在同一个页面中使用两次或以上timepicker,会报一个错误:Maximum call stack size exceeded。同时浏览器卡死。查了下这个错误,是内存溢出,也就是说因为不恰当的代码,导致了递归或是死循环,所以浏览器卡死了。
这可是个致命缺陷啊,比如我一个页面中有两处需要输入日期时间,岂不是只能看着浏览器卡死了?于是本人下决心找到这个问题。为了从原理上了解到底是哪里出现了递归或死循环,我决定把timepicker的源码看一遍。(幸亏源码还不算复杂,代码量不多,而且变量命名规范)~
没看几行就发现问题了,源码从第30行开始,对datepicker的函数进行了重写,典型代码如下:
timepicker的层被挡住了,跟datepicker不在同一高度上。(在十分碰巧的时候才能遇到这种情况,很不幸,我就遇到了--!)
解决方法也很简单,在timepicker的resize()函数中,添加关于z-index的代码即可。修改后的代码如下:
可以看到时分秒那里重复出现了两次,(应该是12:32:00)
所以此处也应该进行一下判断,页面中是否已经存在timepicker了。修改后的代码如下:
if($('#'+this._mainDivId).length==0){$('body').append(this.tpDiv);}
这一下,世界就又美好了~--------------------------------------------------
最后补充一点,就是我使用的timepicker版本,是0.2.1,现在最新的好像有0.3了,不过去官网看了一下,好像变动比较大,使用方法不同了,而且秒也不能显示了。官网:http://milesich.com/