>웹 프론트엔드 >JS 튜토리얼 >브라우저 호환 JS 작성 방법_javascript 기술 요약

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

WBOY
WBOY원래의
2016-05-16 15:03:241067검색

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) 해결책: 텍스트 내용에 "fbd1e5096808aa74fa5b6ea80f0e9fae"와 같은 특수 문자가 포함되어 있지 않으면 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은 d5fd7aea971a85678ba271703566ebfd 및 a1f02c36ba31691bcfe87b2722de723b 요소만 확인하지만 Firefox에서는 모든 요소를 ​​확인합니다.
(2) 해결 방법: d5fd7aea971a85678ba271703566ebfd 및 a1f02c36ba31691bcfe87b2722de723b 이외의 요소를 확인하는 데 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("4216313e5055da45c6d0ded129c5d6443e8e92382b62183bf2604fde8a42078bc02ae4fdd442eb2210bebb17feeb95b4"),而Firefox要使用DOMParser:
        var oParser = new DOMParser();
          var oXmlDom = oParser.parseFromString("66efc7746bfc38acf99d97c3d23ab9c7", "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写法的总结,希望对大家的学习有所帮助。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.