var menu = function(){ var t = 15, z = 50, s = 6, a; function sl(c, f){ var h = c.offsetHeight; if ((h <= 0 && f != 1) || (h >= c.mh && f == 1)) { if (f == 1) { c.style.filter = ''; c.style.opacity = 1; c.style.overflow = 'visible'; } clearInterval(c.t); return } var d = (f == 1) ? Math.ceil((c.mh - h) / s) : Math.ceil(h / s), o = h / c.mh; c.style.opacity = o; c.style.filter = 'alpha(opacity=' + (o * 100) + ')'; c.style.height = h + (d * f) + 'px'; }; function dd(n){ this.h = [];//存取有子菜单的项目 this.c = [];//存取子菜单 }; dd.prototype = { init: function(p, c){ a = c; var that = this; var w = document.getElementById(p), s = w.getElementsByTagName('ul'), l = s.length/*二级菜单的个数*/, i = 0; for (i; i < l; i++) { var h = s[i].parentNode; this.h[i] = h; this.c[i] = s[i]; /* * 重点就在这里,一点JS的语法技巧,通过闭包来实现对i(索引的传递) * 然后就是Javascript里比较奇怪的一点,必须在内部的函数之外声明that=this * 这样对象的作用域才可以保持,很奇怪,但是很有效 */ h.onmouseover = function(index){ return function(){ that.st(index, true); } }(i); h.onmouseout = function(index){ return function(){ that.st(index, false); } }(i); } }, st: function(x, f){ var c = this.c[x], h = this.h[x], p = h.getElementsByTagName('a')[0]; if (c.t) { clearInterval(c.t); } c.style['overflow'] = 'hidden'; if (f) { p.className += ' ' + a; if (!c.mh) { c.style.display = 'block'; c.style.height = ''; c.mh = c.offsetHeight; c.style.height = 0; } if (c.mh == c.offsetHeight) { c.style.overflow = 'visible'; } else { c.style.zIndex = z; z++; c.t = setInterval(function(){ sl(c, 1) }, t); } } else { p.className = p.className.replace(a, ''); c.t = setInterval(function(){ sl(c, -1) }, t); } } }; return { dd: dd }; }();