브라우저 호환 JS 작성 방법_javascript 기술 요약

WBOY
풀어 주다: 2016-05-16 15:03:24
원래의
1002명이 탐색했습니다.

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>
로그인 후 복사
새 코드(IE 및 Firefox에서 작동):

  <input type="button" name="someButton" value="提交" onclick="javascript:gotoSubmit(event)"/>
      ...
      <script language="javascript">
        function gotoSubmit(evt) {
          evt = evt &#63; evt : (window.event &#63; 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(""),而Firefox要使用DOMParser:
var oParser = new DOMParser();
var oXmlDom = oParser.parseFromString("", "text/xml");
(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写法的总结,希望对大家的学习有所帮助。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿