1. 요소 검색 문제
1. document.all[이름]
(1)기존 문제: Firefox는 document.all[이름]
을 지원하지 않습니다.
(2) 해결책: 대신 getElementsByName(name), getElementById(id) 등을 사용하십시오.
2. 컬렉션 개체 문제
(1) 기존 문제: IE에서는 ()를 사용하여 많은 컬렉션 객체에 접근할 수 있지만, Firefox에서는 []만 사용할 수 있습니다.
예: document.forms("formName")는 IE에서 "formName"이라는 이름의 양식을 반환하는 데 사용할 수 있지만 Firefox에서는 작동하지 않습니다.
(2) 해결책: []를 사용하세요. 위의 예에서는 document.forms["formName"]
3. HTML 요소의 ID는 JavaScript에서 볼 수 있습니다
(1) 기존 문제점: IE의 HTML 요소에 있는 ID를 문서의 하위 개체 변수 이름으로 직접 사용할 수 있습니다. 파이어폭스에서는 불가능합니다.
(2) 해결 방법: 개체 변수로 idName 대신 getElementById("idName")를 사용합니다.
4. eval(idName)이 객체를 가져옵니다
(1) 기존 문제: IE에서는 eval(idName)을 사용하여 ID가 idName인 HTML 객체를 얻을 수 있지만 Firefox에서는 얻을 수 없습니다.
(2) 해결책: eval(idName) 대신 getElementById(idName)를 사용하십시오.
5. 변수 이름은 HTML 개체 ID와 동일합니다
(1) 기존 문제점: Firefox에서는 객체 ID를 HTML 객체 이름으로 사용하지 않기 때문에 HTML 객체 ID와 동일한 변수 이름을 사용할 수 있지만 IE에서는 사용할 수 없습니다.
(2) 해결책: 변수를 선언할 때 모호함을 피하기 위해 항상 var를 추가해야 IE에서도 정상적으로 실행될 수 있습니다. 또한 오류를 줄이기 위해 HTML 개체 ID와 동일한 변수 이름을 사용하지 않는 것이 가장 좋습니다.
참고: 3, 4, 5는 모두 동일한 질문 카테고리에 속합니다.
6. 프레임
(1) 기존 문제: IE에서는 window.top.frameId 및 window.top.frameName을 사용하여 Frame으로 표시되는 Window를 가져올 수 있습니다. Firefox에서는 window.top.frameName만 사용할 수 있습니다.
(2) 해결 방법: 프레임의 ID와 이름을 동일하게 설정하고 window.top.frameName을 사용하여 프레임에 액세스합니다.
2. DOM 운영
1. 요소의 텍스트 내용을 설정합니다.
(1) 기존 문제: IE는 innerText를 사용하는 반면 Firefox는 textContent를 사용하여 요소의 텍스트 내용을 설정합니다.
(2) 해결책: 텍스트 내용에 "<" 및 ">"와 같은 특수 문자가 포함되어 있지 않으면 innerHTML을 사용할 수 있습니다. 그렇지 않으면 다음을 사용할 수 있습니다.
var child = elem.firstChild; if (child != null) elem.removeChild(child); elem.appendChild(document.createTextNode(content));
2.부모요소, parent.children
(1) 기존 문제: IE는 parentElement를 사용하여 상위 노드를 가져오고 parent.children을 사용하여 노드의 모든 하위 노드를 가져올 수 있습니다. Firefox에서는 지원되지 않습니다.
(2) 해결책: parentNode 및 parent.childNodes를 사용하십시오.
3. childNodes에 대한 설명입니다.
(1) 기존 문제: IE와 Firefox에서는 childNodes의 해석이 다릅니다. IE는 빈 텍스트 노드를 포함하지 않지만 Firefox는 포함합니다.
(2) 해결 방법: 다음과 같이 childNodes를 사용하여 텍스트 노드를 필터링합니다.
var children = elem.childNodes; for (i = 0; i < children.length; i++) { if (children[i].nodeType != 3) { // 过滤文本结点 // ... } }
4. document.getElementsByName에 대한 설명입니다.
(1) 기존 문제: IE의 getElementsByName은 및 요소만 확인하지만 Firefox에서는 모든 요소를 확인합니다.
(2) 해결 방법: 및 이외의 요소를 확인하는 데 getElementsByName을 사용하지 마세요. 단일 요소를 얻으려면 getElementById를 사용해 보세요.
5. document.getElementById에 대한 설명입니다.
(1) 기존 문제: IE의 getElementById는 Id 속성뿐만 아니라 Name 속성도 확인합니다. Name 속성이 매개변수와 일치하면 해당 요소도 반환됩니다. Firefox에서는 Id 속성만 확인됩니다.
(2) 해결책: 한 요소의 이름 속성을 다른 요소의 id 속성과 동일하게 만들지 마십시오.
3. 이벤트
1. Event.x 및 event.y 문제
(1) 기존 문제: IE에서는 이벤트 객체에 x, y 속성이 있지만 Firefox에서는 그렇지 않습니다.
(2) 해결책: Firefox에서 event.x에 해당하는 것은 event.pageX입니다. 사용 가능:
mX = 이벤트.x ? 이벤트.x : 이벤트.페이지X
2. 윈도우.이벤트
(1) 기존 문제: Firefox에서 window.event 사용이 실행되지 않습니다
(2)해결책:
원본 코드(IE에서 실행 가능):
<input type="button" name="someButton" value="提交" onclick="javascript:gotoSubmit()"/> ... <script language="javascript"> function gotoSubmit() { ... alert(window.event); // use window.event ... } </script>
<input type="button" name="someButton" value="提交" onclick="javascript:gotoSubmit(event)"/> ... <script language="javascript"> function gotoSubmit(evt) { evt = evt ? evt : (window.event ? window.event : null); ... alert(evt); // use evt ... } </script>
3. attachEvent和addEventListener
(1)现有问题:IE中使用attachEvent来添加事件,Firefox中使用addEventListener。
(2)解决方法:如下,注意事件参数的区别,一个是click,一个是onclick。
if (document.attachEvent) document.attachEvent("click", clickHandler,false);
else document.addEventListener("onclick",clickHandler);
四、语法
1. const
(1)现有问题:在IE中不能使用const关键字。如const constVar = 32;在IE中这是语法错误。
(2)解决方法:不使用const,以var代替。
2. 多余的逗号
(1)现有问题:firefox中对象文字常量容许多余的逗号,在IE中不允许。下面语句在IE中非法。
var obj = { 'key' : 'aaa', }
(2)解决方法:去掉多余逗号。
五、XML
1. 创建XMLHttpRequest
(1)现有问题:Firefox使用XMLHttpRequest,IE使用ActiveXObject。
(2)解决方法:
if (window.XMLHttpRequest) { req = new XMLHttpRequest(); } else if (window.ActiveXObject) { req = new ActiveXObject("Microsoft.XMLHTTP"); }
2. 创建DOM
(1)现有问题:Firefox和IE创建DOM的方式不同。
(2)解决方法:
function createXmlDom() { var oXmlDom; if (Window.ActiveXObject) { // IE oXmlDom = new ActiveXObject("Microsoft.XmlDom"); } else { // Firefox oXmlDom = document.implementation.createDocument("", "", null); } }
3. 加载XML
(1)现有问题:如果要加载外部文件IE和Firefox都可以用:
oXmlDom.async=false; // 这在Firefox中是必须的
oXmlDom.load("test.xml");
但是它们加载xml字符串的方式不一样,IE中直接可以使用oXmlDom.loadXML("
var oParser = new DOMParser();
var oXmlDom = oParser.parseFromString("
(2)解决方法:比较好的方法是给Firefox产生的XMLDom加上loadXML方法:
if (isFirefox) { // 需要浏览器检测
Document.prototype.loadXML = function(sXml) { var oParser = new DOMParser(); var oXmlDom = oParser.parseFromString(sXml, "text/xml"); while (this.firstChild) this.removeChild(this.firstChild); for (var i = 0; i < oXmlDom.childNodes.length; i++) { var oNewNode = this.importNode(oXmlDom.childNodes[i], true); this.appendChild(oNewNode); } } }
这样在IE和Firefox就可以调用loadXML方法了。
4. XPath支持
(1)现有问题:IE中可以直接用XmlDOM的selectNodes来根据XPath表示式来选择结点,Firefox则比较复杂,需要使用XPathEvaluator。
IE:
var lstNodes = oXmlDom.documentElement.selectNodes("employee/name"); for (var i = 0; i < lstNodes.length; i++) { alert(lstNodes[i].firstChild.nodeValue); }
Firefox:
var oEvaluator = new XPathEvaluator(); var oResult = oEvaluator.evaluate("employee/name", oXmlDom.documentElement, null, XPathResult.ORDERED_NODE_ITERATOR_TYPE, null); var oElement = oResult.iterateNext(); while (oElement) { alert(oElement.firstChild.nodeValue); oElement = oResult.iterateNext(); }
(2)解决方法:比较好的方法给Firefox的Element添加selectNodes方法。
if (isFirefox) { // 需要浏览器检测 Element.prototype.selectNodes = function(sXPath) { var oEvaluator = new XPathEvaluator(); var oResult = oEvaluator.evaluate(sXPath, this, null, XPathResult.ORDERED_NODE_ITERATOR_TYPE, null); var aNodes = new Array(); if (oResult != null) { var oElement = oResult.iterateNext(); while (oElement) { aNodes.push(oElement); oElement = oResult.iterateNext(); } } return aNodes; } }
这样在IE和Firefox中就都可以调用selectNodes方法了。
5. XSLT支持
(1)现有问题:IE中可以使用XmlDOM的transferNode方法将其转换成html,而Firefox需要使用XSLTProcessor。
IE:
oXmlDom.load("employee.xml"); oXslDom.load("employee.xslt"); var sResult=oXmlDom.transformNode(oXslDom);
Firefox:
var oProcessor = new XSLTProcessor(); oProcessor.importStylesheet(oXslDom); var oResultDom = oProcessor.transformToDocument(oXmlDom); var oSerializer = new XMLSerializer(); var sXml = oSerializer.serializeToString(oResultDom, "text/xml"); alert(sXml);
(2)解决方法:比较好的方法给Firefox的Node添加transferNode方法。
if (isFirefox) { // 需要浏览器检测 Node.prototype.transformNode = function(oXslDom) { var oProcessor = new XSLTProcessor(); oProcessor.importStylesheet(oXslDom); var oResultDom = oProcessor.transformToDocument(oXmlDom); var oSerializer = new XMLSerializer(); var sXml = oSerializer.serializeToString(oResultDom, "text/xml"); return sXml; } }
这样在IE和Firefox中就都可以调用transferNode方法了。
以上就是针对浏览器兼容的JS写法的总结,希望对大家的学习有所帮助。