遞規法遍歷xml樹的屬性和節點值,並將其批次放入陣列 (轉)

amyz發表於2007-11-25
遞規法遍歷xml樹的屬性和節點值,並將其批次放入陣列 (轉)[@more@]

遞規法遍歷樹的屬性和節點值

注: function xml2script(xml_name, data) //引數xml_name: xml文件名,data:資料的陣列名 轉換成功後陣列,基本按照的呼叫方法,只不過將'()'轉換為'[]'

/**
 * 遞迴法讀xml所有資料(包括屬性值)放入陣列
 *
 * MEMBER >>
 *
 *
 * RETURN >>
 *
 *
 * 建立者: 建立時間:
 *
 * 編寫者:wyc 編寫時間:02-12-7
 *
 * 修改者: 修改時間: 新增功能:
 *
 */
function xml2javascript(xml_name, data)
{
 // +----------------------------------------------------+
 // | 建立MSXML.DOMDocument |
 var xml_doc = new ("MSXML.DOMDocument");
 xml_doc.async = false;
 xml_doc.load(xml_name);
 // +----------------------------------------------------+
 var obj  = xml_doc.documentElement;
 var data_obj = data;
 eval(data_obj + "=new Object();");
 _getXml(obj, data_obj)
}

/**
 * 內部
 *
 * MEMBER >>
 *
 *
 * RETURN >>
 *
 *
 * 建立者: 建立時間:
 *
 * 編寫者:wyc 編寫時間:02-12-7
 *
 * 修改者: 修改時間: 新增功能:
 *
 */
function _getXml(obj, data_obj)
{
 var node_count = obj.childNodes.length;
 if (node_count == 0) { //如果沒有子節點,那麼返回
 return;
 }
 eval(data_obj + ".childNodes=new Array();");
 eval(data_obj + "._childNodes=new Array();");
 for (var i=0; i if (obj.childNodes(i).nodeName == '#text') {
 eval(data_obj + ".text=obj.text;"); //元素名稱
 return;
 }
 if (obj.childNodes(i).nodeName == '#cdata-section') {
 eval(data_obj + ".text= obj.text;");
 return;
 }
 eval(data_obj + ".childNodes[i]=new Object();"); //新建一個元素
 eval(data_obj + ".childNodes[i].nodeName=obj.childNodes(i).nodeName;"); //元素名稱
 
 eval(data_obj + "._childNodes[obj.childNodes(i).nodeName]=i;"); //元素快取

 //屬性
 var attribute_count = obj.childNodes(i).attributes.length;
 eval(data_obj + ".childNodes[i].attributes=new Array();"); //屬性陣列
 eval(data_obj + ".childNodes[i]._attributes=new Array();"); //屬性快取陣列
 for (var j=0; j eval(data_obj + ".childNodes[i].attributes[j]=new Object();");
 eval(data_obj + ".childNodes[i].attributes[j].nodeName=obj.childNodes(i).attributes(j).nodeName;");
 eval(data_obj + ".childNodes[i].attributes[j].text=obj.childNodes(i).attributes(j).text;");
 
 eval(data_obj + ".childNodes[i]._attributes[obj.childNodes(i).attributes(j).nodeName]=j;");
 }
 
 var obj_  = obj.childNodes(i);
 var data_obj_ = data_obj + ".childNodes[" + i + "]";
 _getXml(obj_, data_obj_);
 }
}

//呼叫示例
xml2javascript('message.xml', 'aaa');
alert(aaa.childNodes[0].childNodes[1].nodeName);
alert(aaa.childNodes[0].childNodes[1].text);
//alert(aaa.childNodes[0].childNodes[1].attributes[0].text);



來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752019/viewspace-984612/,如需轉載,請註明出處,否則將追究法律責任。

相關文章