浏览器之争着实给开发者带来了诸多不便利,还好各个浏览器基本都有自己的扩展机制。这里就贴一个js文件,引用了该文件的页面允许对firefox进行部分的扩展,以期待跟IE拥有相似的效果。
其中__defineGetter__, __defineSetter__扩展方式详见这里:点击进入。
file:\\__firefox_extension.js

/**//*firefox window.event*/
function __firefox()


{
HTMLElement.prototype.__defineGetter__("runtimeStyle", __element_style);
window.constructor.prototype.__defineGetter__("event", __window_event_constructor_getter);
window.constructor.prototype.__defineSetter__("event", __window_event_constructor_setter);
Event.prototype.__defineGetter__("srcElement", __event_srcElement);
HTMLElement.prototype.__defineGetter__("outerHTML",__element_outerHTML_getter);
HTMLElement.prototype.__defineSetter__("outerHTML",__element_outerHTML_setter);
HTMLElement.prototype.__defineGetter__("canHaveChildren",__canHaveChildren_getter);
}

function __canHaveChildren_getter()
{
return !/^(area|base|basefont|col|frame|hr|img|br|input|isindex|link|meta|param)$/.test(this.tagName.toLowerCase());
}

function __element_outerHTML_setter(s)
{
var r = this.ownerDocument.createRange();
r.setStartBefore(this);
var df = r.createContextualFragment(s);
this.parentNode.replaceChild(df, this);
return s;
}

function __element_outerHTML_getter()
{
var a=this.attributes, str="<"+this.tagName, i=0;for(;i<a.length;i++)
if(a[i].specified) str+=" "+a[i].name+'="'+a[i].value+'"';
if(!this.canHaveChildren) return str+" />";
return str+">"+this.innerHTML+"</"+this.tagName+">";
}
function __element_style()


{
return this.style;
}

function __event_srcElement()


{
return this.target;
}
function __window_event_constructor_getter()


{
if(document.all)

{
return window.event;
}
var _caller = __window_event_constructor.caller;

while(_caller!=null)
{
var _argument = _caller.arguments[0];

if(_argument)
{
var _temp = _argument.constructor;
if(_temp.toString().indexOf("Event")!=-1)

{
return _argument;
}
}
_caller = _caller.caller;
}
return null;
}
function __window_event_constructor_setter(e)


{
//
}
if(window.addEventListener)


{
__firefox();
}


/**//*end firefox.event*/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端