在 http://spyrise.org/blog/category/iPod/ 里,我编写了一个用Javascript来生成iPod所用的vCard文件。
最近,我决定重写一下代码,优化一下。因为我必须做到IE和Firefox效果相同,所以调试了好久。无意中,我发现了两个关于IE奇怪的现象。
1) 如果你使用<textarea id="inputArea"> </textarea>。当你复制一大段文字进入这个TEXTAREA输入框。然后用alert(document.getElementById("inputArea").value.length)来获取输入文字的字数时,你会发现IE报告的字数会比Firefox多一些。
什么原因呢?原因是IE关于换行符的解释为\r\n,而firefox是\n,少了一个\r。每一个换行符,就会差一个字。而实际情况中,会有很多段落,自然两者的长度会不一样了:IE会比Firefox多一些字节。我们可以使用以下代码来消除IE中的\r。
在进行了以上去除\r的操作后,两者的字符串长度就相同了。
2) 如果你使用 inputArea=document.getElementById("inputArea").value 的Javascript代码时,Firefox不会告诉你这个是错误,但IE会奇怪地报告:该对象不支持此方法或属性。原因是变量名与Id名相同了。虽然我认为,前者是变量,后者是DOM对象,根本就是两回事,为何不可这么写,但事实就是这样。如果你在最前面加上var,则可以:var inputArea=document.getElementById("inputArea").value。但是即使这么写,后来我发现我陷入了混乱,而且不明白为何会这样。最后我只好将原Id名从inputArea改名至v_inputArea来解决这个问题。
