> 웹 프론트엔드 > JS 튜토리얼 > javascript_javascript 기술의 dom 및 xml 노드 액세스와 관련된 호환성 문제

javascript_javascript 기술의 dom 및 xml 노드 액세스와 관련된 호환성 문제

WBOY
풀어 주다: 2016-05-16 19:07:44
원래의
1000명이 탐색했습니다.

최근에 브라우저 호환성 문제를 정리했는데, 선배님들의 도움으로 어느 정도 진전을 이루었습니다. 아래에 코드를 좀 올려두겠습니다.

코드 복사 코드는 다음과 같습니다.

var isIE = ????;
//전역 변수, IE 여부 결정, 자체 개선
// 새 dom 메서드
function parseXML(st){
if ( isIE){
var result = new ActiveXObject( "microsoft.XMLDOM" );
result.loadXML(st)
} else {
var parser = new DOMParser(); var result = parser.parseFromString(st, "text/xml" );
}
return result;
}
if (!isIE){
var ex; 정의 노드 xml 속성
XMLDocument.prototype.__proto__.__defineGetter__( "xml" , function (){
try {
return new XMLSerializer().serializeToString( this );
          } catch(예) {
var d = document.createElement("div");
d.appendChild(this .cloneNode(true));
return d.innerHTML;                                                                                                        > Element.prototype.__proto__.__defineGetter__( "xml " , function (){
try {
return new XMLSerializer().serializeToString(this);
} c atch (ex){
var d = document.createElement( "div" );
d.appendChild( this .cloneNode( true ));
return d.innerHTML;
//노드 텍스트 속성 정의
"text" , 함수 (){
return this .textContent
})
// selectSingleNode, selectNodes 메서드 정의
XMLDocument.prototype.selectSingleNode = Element.prototype.selectSingle Node = function (xpath){
var x = this .selectNodes(xpath)
if ( ! x || x.length < 1 ) return null
return x[0]

    XMLDocument.prototype.selectNodes = Element.prototype.selectNodes = 함수(xpath){ 
         var  xpe  =   new  XPathEvaluator(); 
         var  nsResolver  =  xpe.createNSResolver( this .ownerDocument  ==   null   ?  
            이 .documentElement :  this .ownerDocument.documentElement); 
         var  결과  =  xpe.evaluate(xpath,  this , nsResolver,  0 ,  null ); 
         var  찾음  =  []; 
         var  res; 
         동안  (res  =  result.iterateNext()) 
            found.push(res); 
         반품  찾음; 
    } 

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