`
xwhoyeah
  • 浏览: 91564 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

使用 javascript 移动 xmlDom 节点

阅读更多
<html>
<header><title>使用 javascript 移动 xmlDom 节点.</title></header>
<body>
<textarea id='log0' rows='10' cols='100'>
<?xml version="1.0"?>
<web-app>
    <welcome-file>3333index.html</welcome-file>
</web-app></textarea>
<textarea id='log1' rows='10' cols='100'>
<?xml version="1.0"?>
<web-app>
  <welcome-file>1111index.html</welcome-file>
  <welcome-file-list>
    <welcome-file>2222index.html</welcome-file>
  </welcome-file-list>		
</web-app></textarea>
<br><button onclick="parse1()"> parse1 </button>  
<button onclick="parse2()"> parse2 </button>
<br>
<textarea id='log2' rows='30' cols='100'></textarea>

<SCRIPT   LANGUAGE=javascript>
function parse1(){
    
  var xmlDoc0 = new   ActiveXObject("Microsoft.XMLDOM");
  xmlDoc0.loadXML( document.getElementById('log0').value );
  
  var xmlDoc1 = new   ActiveXObject("Microsoft.XMLDOM");
  xmlDoc1.loadXML( document.getElementById('log1').value );
    
  if( xmlDoc0.readyState==4 && xmlDoc1.readyState==4){     
    rootNode0 = xmlDoc0.documentElement;   
    xml = '';
    xml = scanXml(rootNode0, xml, 0);      
    document.getElementById('log2').value += 
        "\n\n-------------------------------------xmlDoc0";
    document.getElementById('log2').value += xml;

    rootNode1 = xmlDoc1.documentElement;
    moveElement(rootNode0, rootNode1);    
    xml = '';
    xml = scanXml(rootNode1, xml, 0);      
    document.getElementById('log2').value += 
        "\n\n-------------------------------------xmlDoc1";
    document.getElementById('log2').value += xml;

    xml = '';
    xml = scanXml(rootNode0, xml, 0);      
    document.getElementById('log2').value += 
        "\n\n-------------------------------------xmlDoc0";
    document.getElementById('log2').value += xml;
  }
}

function moveElement( sourceNode, descNode ){  
  while( sourceNode.hasChildNodes() ){
    [b]//将会从 sourceNode 移除节点.[/b]
    descNode.appendChild( sourceNode.firstChild );        
  }
}

function nSpace( n ){
  var space ="";
  for(var i=0; i< n; i++){
    space += "--";
  }
  return space;
}   

function scanXml(xmlNode, xml, level){
  var currXml = '';
  var currLevel = level + 1;  
  //alert( xmlNode.nodeType + ":" + xmlNode.nodeName );
  //nodeType 此属性只读且传回一个数值。有效的数值符合以下的型别: 
  switch( xmlNode.nodeType ){
    case 1: //-ELEMENT
      currXml += "\n" + nSpace( level ) + "<" + xmlNode.nodeName + ">";
      if(xmlNode.hasChildNodes()){
        var   nodeList   =   xmlNode.childNodes;
          for(var   i=0;i<nodeList.length;i++){
            currXml = scanXml(nodeList[i], currXml, currLevel);
          }
      }
      currXml += "\n" + nSpace( level ) + "</" + xmlNode.nodeName + ">";
      break;
    case 2: break;//-ATTRIBUTE 
    case 3: //-TEXT      
      currXml = "\n" + nSpace( level ) + xmlNode.nodeValue;
      break;
    case 4: break;//-CDATA 
    case 5: break;//-ENTITY REFERENCE 
    case 6: break;//-ENTITY 
    case 7: break;//-PI (processing instruction) 
    case 8: break;//-COMMENT 
    case 9: break;//-DOCUMENT 
    case 10: break;//-DOCUMENT TYPE 
    case 11: break;//-DOCUMENT FRAGMENT 
    case 12: break;//-NOTATION 
    default:
  }
  return xml + currXml;
}
</SCRIPT>  
</body>
</html>



参照:  http://www.w3sky.com/2/2550.html    
分享到:
评论

相关推荐

    XML DOM教程

    DOM提供了丰富的接口来处理XML文档,包括创建新节点、删除节点、复制节点、移动节点以及更新节点属性等操作。通过熟练掌握DOM,开发者可以构建动态、交互式的Web应用程序,实现对XML数据的强大控制。

    JavaScript&DHTML&CSS中文版参考大全【附:XMLDom.chm】.rar

    XMLDOM提供了对XML节点的遍历、创建、修改和删除等操作。在JavaScript中,XMLHttpRequest对象可以用来加载XML文档,然后通过XMLDOM解析并操作XML数据,常用于数据交换和服务器通信。 **CSS** (Cascading Style ...

    JS操作XMLDOM(遍历和打印)

    这篇博客"JS操作XMLDOM(遍历和打印)"很可能探讨了如何利用JavaScript来处理XML数据,特别是遍历XML结构并将其打印出来。 XML是一种结构化数据格式,常用于存储和传输数据。在JS中,XMLDOM允许我们将XML文档转换为一...

    XMLDom参考手册

    - **内存管理**:及时释放不再使用的DOM节点,防止内存泄漏。 7. **XML DOM与HTML DOM** - **共性**:XML DOM和HTML DOM在基本原理上是相同的,都遵循W3C的DOM标准。 - **差异**:HTML DOM对某些HTML特有的元素...

    javascript节点操作DOM属性和方法

    在JavaScript中,我们可以通过以下方式访问DOM节点: 1. `getElementById()`:通过元素的ID获取节点,这是最直接的方法。 2. `getElementsByClassName()`:返回具有特定类名的所有元素的NodeList。 3. `...

    css+DHTML+js+XMLDOM手册

    XMLDOM提供了诸如节点操作(如创建、删除和移动节点)、查找特定节点、以及设置和获取属性值等功能,使得处理XML数据变得更为方便。 这些手册将涵盖CSS的语法、选择器、布局技巧;DHTML的动态效果实现、DOM操作;...

    xml.rar_DOM_XML DOM_dom xml_xml

    例如,JavaScript中使用`document.implementation.createDocument()`方法或`DOMParser`对象来解析XML。 4. **访问节点**:使用DOM API,可以通过节点名称、索引或路径(如XPath)来查找特定节点。例如,`...

    javascript 操作DOM

    访问DOM节点通常通过`getElementById`、`getElementsByClassName`、`getElementsByTagName`、`querySelector`和`querySelectorAll`等方法完成。例如,`getElementById`用于获取具有特定ID的元素,而`...

    JavaScript.DOM编程艺术(第2版)附录及源码.rar

    7. **DOM操作**:创建新节点、插入和删除节点、复制和移动节点等,都是DOM编程中的基本操作。 8. **DOM事件委托**:利用事件冒泡或事件捕获机制,可以有效地处理大量元素的事件,提高性能。 9. **DOM性能优化**:...

    javaScript-DOM编程艺术

    JavaScript-DOM编程艺术是关于如何使用JavaScript操作网页文档对象模型(Document Object Model,简称DOM)的技术。DOM是一种标准,它提供了表示和操作HTML或XML文档的接口。通过DOM,JavaScript可以访问和修改网页...

    JS dom节点实现移上、移下的效果(表格).zip

    在这个场景下,我们将关注如何利用DOM节点来实现表格内容的移动,如上下移动,以及表格的添加和删除功能。 首先,我们需要理解表格在HTML中的结构。一个基本的表格由`&lt;table&gt;`标签定义,其中包含`&lt;tr&gt;`(行)和`...

    原生js操作dom实现上下左右移动.docx

    本文将详细讲解如何使用原生JavaScript操作DOM实现上下左右移动的功能。首先,我们需要了解什么是DOM,以及如何使用JavaScript来操作DOM。 DOM(Document Object Model,文档对象模型)是HTML和XML文档的编程接口。...

    DOMExample.rar XMLDOM例子

    6. **操作(Manipulation)**:可以创建新的节点,删除已有的节点,修改节点内容,或者移动节点位置,实现对XML文档的动态修改。 7. **事件(Events)**:在JavaScript中,DOM还支持事件处理,可以绑定事件监听器,...

    JavaScript DOM编程艺术

    4. **创建和删除节点**:使用`createElement`、`appendChild`、`insertBefore`、`removeChild`等方法可以动态创建、插入、移动或删除DOM节点,实现网页的动态更新。 5. **修改节点内容**:`innerHTML`属性用于设置...

    JavaScript DOM编程艺术 第2版+代码

    这涉及到获取和设置元素的样式属性,以及使用CSS选择器来选取特定的DOM节点。 书中还涉及了Ajax技术,即异步JavaScript和XML,用于实现无刷新的数据交换,提升用户体验。通过创建XMLHttpRequest对象,开发者可以向...

    javascriptDOM

    JavaScript DOM(Document Object Model)是Web开发中的一个关键概念,它允许我们通过编程方式与HTML或XML文档交互。DOM是一个树形结构,将网页内容分解为独立的对象,这些对象可以被JavaScript或者其他脚本语言访问...

    JavaScript DOM编程艺术 第2版 及源码

    2. **选择元素**:书中详细介绍了如何使用`getElementById`、`getElementsByTagName`、`getElementsByClassName`等方法以及CSS选择器来选取网页中的特定元素,这些都是JavaScript DOM编程的基础。 3. **事件处理**...

    Javascript DOM编程艺术 中文版

    2. **DOM基础**:阐述DOM的概念,DOM树的构建,以及如何通过JavaScript获取和遍历DOM节点。 3. **事件处理**:讲解JavaScript如何响应用户的交互,如点击、鼠标移动等,以及事件冒泡和事件捕获的概念。 4. **DOM操作...

    JavaScript-DOM.rar_javascript

    事件可以绑定到任何DOM节点上,如点击(click)、鼠标移动(mousemove)等,从而实现交互效果。 六、DOM性能优化 DOM操作往往会导致浏览器重新渲染,频繁操作可能会影响页面性能。为了优化,可以: 1. 使用文档碎片...

    Javascript--DOM.rar_javascript

    在JavaScript中,我们通常使用`document`对象来访问和操作DOM。 二、选择DOM元素 1. `getElementById`: 根据ID选择元素,例如:`document.getElementById('myElement')` 2. `getElementsByClassName`: 根据类名选择...

Global site tag (gtag.js) - Google Analytics