<strong>关于用脚本设置onload事件句柄</strong> <br><div class="htmlarea"> <textarea id="runcode66521"> <script> document.body.onload=function(){alert("!")} </script> </textarea><br><input onclick="runEx('runcode66521')" type="button" value="运行代码"> <input onclick="doCopy('runcode66521')" type="button" value="复制代码"> <input onclick="doSave(runcode66521)" type="button" value="保存代码">[Ctrl+A 全选 注:<a href="http://www.jb51.net/article/23421.htm" title="查看具体详情" target="_blank">如需引入外部Js需刷新才能执行</a>]</div> <br>在IE、Opera均正常有效,唯独FF既不执行,也不报错,因为在FF,document.body.onload是undefined(未定义),把一个函数赋值给undefined既不会发生什么事情,也不算出错。<br>这么写的在IE、Opera和FF都有效:<br><div class="htmlarea"> <textarea id="runcode58235"> <script> window.onload=function(){alert("!")} </script> </textarea><br><input onclick="runEx('runcode58235')" type="button" value="运行代码"> <input onclick="doCopy('runcode58235')" type="button" value="复制代码"> <input onclick="doSave(runcode58235)" type="button" value="保存代码">[Ctrl+A 全选 注:<a href="http://www.jb51.net/article/23421.htm" title="查看具体详情" target="_blank">如需引入外部Js需刷新才能执行</a>]</div> <br><strong>关于用脚本绑定事件句柄</strong> <br>IE 下用 attachEvent, FF 下用 addEventListener<br><br>相关讨论如下:<br><a href="http://search.blueidea.com/?q=addEventListener&bisearch=bbs" target="_blank">http://search.blueidea.com/?q=addEventListener&bisearch=bbs</a><br>(基本上看几贴就明白了,我就不详细说了。请大家看的时候不要顶老贴,谢谢)<br><br>参考链接:<br><a href="http://bbs.blueidea.com/viewthread.php?tid=2248795&page=1#pid2248824" target="_blank">http://bbs.blueidea.com/viewthre ... p;page=1#pid2248824</a><br><a href="http://bbs.blueidea.com/viewthread.php?tid=2507914" target="_blank">http://bbs.blueidea.com/viewthread.php?tid=2507914</a><br><strong>关于浮动代码和 documentElement / body</strong> <br>常常有人提问,为什么 漂浮广告 / 对联代码 在 xHTML 1.1 DTD 文件头 / FF 下不能使用 <br>这是因为,按照标准来说,我们看到的窗体的滚动条不应该是 body 的,而是 HTML 的(也就是 document.documentElement 对象)<br>所以,解决办法是,把以前不标准的代码中, document.body.scrollTop 或者类似的代码变换为 document.documentElement.scrollTop<br><strong>关于 ID 与 html 对象元素的引用</strong> <br>这个问题的原因非常非常多。但是一个基本的前提条件就是,对于IE 来说,一个HTML 元素的 ID 可以直接在脚本中当作变量名来使用,而 FF 中不可以。<br><div class="codetitle"> <span><a style="CURSOR: pointer" data="35106" class="copybut" id="copybut35106" onclick="doCopy('code35106')"><u>复制代码</u></a></span> 代码如下:</div> <div class="codebody" id="code35106"> <input><input> </div> <br><div class="codetitle"> <span><a style="CURSOR: pointer" data="61809" class="copybut" id="copybut61809" onclick="doCopy('code61809')"><u>复制代码</u></a></span> 代码如下:</div> <div class="codebody" id="code61809"> <input><input> </div> <br>关于 事件对象的使用差异<br>IE 中,事件激发的时候,有一个全局的 window.event 对象保存了事件的相关信息<br>IE Only <br><div class="htmlarea"> <textarea id="runcode31902"> <input type="button" onclick="alert(event.type)" onfocus="alert(event.type)"> </textarea><br><input onclick="runEx('runcode31902')" type="button" value="运行代码"> <input onclick="doCopy('runcode31902')" type="button" value="复制代码"> <input onclick="doSave(runcode31902)" type="button" value="保存代码">[Ctrl+A 全选 注:<a href="http://www.jb51.net/article/23421.htm" title="查看具体详情" target="_blank">如需引入外部Js需刷新才能执行</a>]</div> <br>FF 中,事件激发的时候,将一个局部的 event 对象作为第一个参数传递给了事件处理函数 <br>FF Only<br><div class="htmlarea"> <textarea id="runcode71422"> <input type="button" onclick="alert(arguments[0].type)" onfocus="alert(arguments[0].type)"> </textarea><br><input onclick="runEx('runcode71422')" type="button" value="运行代码"> <input onclick="doCopy('runcode71422')" type="button" value="复制代码"> <input onclick="doSave(runcode71422)" type="button" value="保存代码">[Ctrl+A 全选 注:<a href="http://www.jb51.net/article/23421.htm" title="查看具体详情" target="_blank">如需引入外部Js需刷新才能执行</a>]</div> <br>此外,IE 的 event 对象和 FF 的 event 对象还稍有不同。 <br>以下是我常用的兼容形式 <br><div class="htmlarea"> <textarea id="runcode52860"> <script> function doEvent(e){ var e=window.event?window.event:e; var srcEle=e.srcElement?e.srcElement:e.target; alert(srcEle.value); } </script> <input value="click me" onclick="doEvent(arguments[0]);"> </textarea><br><input onclick="runEx('runcode52860')" type="button" value="运行代码"> <input onclick="doCopy('runcode52860')" type="button" value="复制代码"> <input onclick="doSave(runcode52860)" type="button" value="保存代码">[Ctrl+A 全选 注:<a href="http://www.jb51.net/article/23421.htm" title="查看具体详情" target="_blank">如需引入外部Js需刷新才能执行</a>]</div> <br>参考<br><a href="http://bbs.blueidea.com/thread-2667939-1-1.html" target="_blank">http://bbs.blueidea.com/thread-2667939-1-1.html</a>