我有一个处理鼠标按钮事件的 JavaScript 函数。它必须能够区分鼠标左键和右键。遗憾的是,Internet Explorer 对 event.button 使用的值与所有其他浏览器不同。我知道如何解释它们,但我需要知道该走哪条路。
我通过依赖条件编译的 JavaScript hack 做到了这一点。就像这样:
if (/*@cc_on!@*/false) { IE fixup... }
我认为这是一种相当安全的方法,因为它基于 JavaScript 解析器功能,无法伪造,也不太可能被其他浏览器模仿。
现在我正在使用 Google Closure Compiler 来打包我的 JavaScript 文件。我发现它也像任何其他注释一样删除了条件编译注释。所以我尝试了不同的技巧。其中之一是这样的:
if ("\v" == "v") { IE fixup... }
不幸的是,闭包编译器非常聪明,发现条件永远不会为真并删除该代码。另外,我不喜欢它,因为微软最终可能会修复那个 \v 错误,然后检测失败。
我可以只阅读类似 navigator.appName 或它的名称之类的内容,但这太容易伪造了。如果有人修改了他们的浏览器标识,他们不太可能实现其他 event.button 行为......
闭包编译器允许保留某些注释。我试过这个:
if (/**@preserve/*@cc_on!@*/false) { IE fixup... }
虽然这会在压缩后产生所需的结果,但它不是源形式的功能性条件注释。但出于调试原因,我需要我的 JavaScript 文件在压缩和未压缩的情况下都可以工作。
我有没有希望在不手动修改压缩的 JS 文件的情况下让它工作?
作为参考,这是我原始形式的完整功能:
function findEvent(e)
{
e = e || event; // IE
if (!e.target && e.srcElement) // IE
e.target = e.srcElement;
if (isSet(e.button))
{
// Every browser uses different values for the mouse buttons. Correct them here.
// DOM says: 0 = left, 1 = middle, 2 = right (multiple buttons not supported)
// Opera 7 and older and Konqueror are not specifically handled here.
// See http://de.selfhtml.org/javascript/objekte/event.htm#button
if (/*@cc_on!@*/false) // IE - http://dean.edwards.name/weblog/2007/03/sniff/ - comment removed by Google Closure Compiler
{
if (e.button & 1)
e.mouseButton = 0;
else if (e.button & 2)
e.mouseButton = 2;
else if (e.button & 4)
e.mouseButton = 1;
}
else
e.mouseButton = e.button;
}
return e;
}