使用||运算符指定一个默认值
事件处理程序依赖于浏览器。理想情况下,应用程序应该通过公共库隔绝对浏览器的依赖。当没有这样的库时,就会有些函数发生如下情况:
function md(e) { (window.event) ? ev = window.event : ev = e; (ev.target) ? sr = ev.target : sr = ev.srcElement; if (ev && sr && sr.id == "fp" || sr.id == "sb") st = 1; if (sr.className.indexOf("pllist") < 0 && sr.className != "more" && sr.className != "plinkc" && sr.tagName != "scrollbar " && _toClose && _toCloseNorgie) { d.getElementById(_toClose).innerHTML = ""; _toClose = ""; _toCloseNorgie.parentNode.className = ''; _toCloseNorgie = ''; } }
一些浏览器把事件对象作为一个参数传给事件管理程序。微软选用把事件对象放入到一个全局的事件变量中。在Javascript中,全局变量是全局对象的成员。在浏览器中,全局对象始终包含一个window对象成员,其值是全局对象。当测试一个变量是否存在时,通过window访问全局变量是避免未定义变量错误的一种方法。无论如何,做这样的测试不应该是必要的。
我们能通过问它是否是另外一种,来代替首先判断是否是微软事件。
ev = e || event;我们用||(默认)运算符。如果e是真,我们将有它的值,但是如果e是假,则我们将用event。
在下一个语句,我们又用||运算符去确定sr是哪个值。
我们应该用var去声明ev和sr来避免全局冲突:
function md(e) { var ev = e || event, sr = ev.target || ev.srcElement; if (sr && (sr.id == 'fp' || sr.id == 'sb')) { st = 1; } if (sr.className.indexOf('pllist') < 0 && sr.className != 'more' && sr.className != 'plinkc' && sr.tagName != 'scrollbar ' && _toClose && _toCloseNorgie) { d.getElementById(_toClose).innerHTML = ''; _toClose = ''; _toCloseNorgie.parentNode.className = ''; _toCloseNorgie = ''; } }
全局变量是魔鬼
下面我们看到另一个时间处理程序。正如你所料,它重复像前面一样破坏风格。
function kd(e) { (window.event) ? ev = window.event : ev = e; (ev.target) ? el = ev.target : el = ev.srcElement; if (ev && el) { code = ev.keyCode; id = el.id; } else { return; } ctn = lt.id.substring(1); if (code == 13) { return; } else if ((code == 191 || code == 222) && id != 'fp') { _ffs = 1; gk = 0; } else if ((code < 31 || code > 41) && (code < 16 || code > 18) && code != 9 && code != 8 ) { gk = 1; } else { gk = 0; } if (!_ffs && (id == 'fp' || id == 'st')) { if (code == 9) { if (box.value == '' || (box.value != '' && (at == 1 || ev.shiftKey))) { mt(ctn); } else if (id == 'st' && box.value != '' && at == 0) { at = 1; mt(ctn); } } else if (id == 'fp' && gk == 0 && (box.value == '' && st == 0) && !ev.shiftKey && !ev.ctrlKey && !ev.altKey) { d.getElementById('mk').focus(); d.getElementById('mk').blur(); } else if (gk == 1) { at = 0; } } else if ((id == 'mk2' && box.value != '' && ev.shiftKey && code == 9) || (id == 'm6' && !ev.shiftKey && code == 9)){ d.getElementById('mk').focus(); } else if (!_ffs && gk == 1 && el.type != 'text' && !ev.ctrlKey && !ev.altKey){ box.value = ''; box.focus(); } } function mt(ctn) { if ((ev && !ev.ctrlKey && !ev.altKey) || !ev) { if (ev.shiftKey){ nextTab = parseInt(ctn) - 1; } else { nextTab = parseInt(ctn) + 1; } if (nextTab == 0) { d.getElementById('mk').focus(); } else if (nextTab < 8 ) { t(d.getElementById('v' + nextTab)); } else { return; } } }
有意思的是它有一个同伴函数mt,它仅被kd调用。mt被传给一个参数ctn,但kd和mt之间的通讯大部分是通过全局变量。
出处:随网之舞
责任编辑:bluehearts
上一页 Javascript风格要素 [1] 下一页 Javascript风格要素 [3]
◎进入论坛网页制作、WEB标准化版块参加讨论,我还想发表评论。
|