2013-08-02 124 views
1

我只想循環具有屬性New =「True」的元素 - 而不是在循環內部使用If語句。這怎麼可能? (我希望這將提供更好的性能)只在ASP中循環具有特定屬性的XML元素

ASP:

<% 
Set objXMLDoc = Server.CreateObject("MSXML2.DOMDocument.3.0")  
objXMLDoc.async = False  
objXMLDoc.load Server.MapPath("/data.xml") 
Dim xmlProduct  
For Each xmlProduct In objXMLDoc.documentElement.selectNodes("Product") 
    Dim productCode : productCode = xmlProduct.selectSingleNode("ProductCode").text 
    Dim productName : productName = xmlProduct.selectSingleNode("ProductName").text 
    Response.Write Server.HTMLEncode(productCode) & " - " 
    Response.Write Server.HTMLEncode(productName) & "<br>" 
Next 
%> 

XML:

<Products> 
    <Product New="True"> 
    <ProductCode>1234</ProductCode> 
    <ProductName>Bike</ProductName> 
    </Product> 
    <Product New="False"> 
    <ProductCode>1235</ProductCode> 
    <ProductName>Car</ProductName> 
    </Product> 
    <Product New="True"> 
    <ProductCode>1236</ProductCode> 
    <ProductName>Plane</ProductName> 
    </Product> 
</Products> 

回答

2

可以查詢和使用XPATH篩選XML文檔:

Dim xpath : xpath = "/*/Product[@New='True']" 

Dim xml 
Set xml = CreateObject("Msxml2.DOMDocument") 
    xml.async = False 
    xml.loadXML([YOUR XML STRING]) 

    Dim root, xmlNodes, x 
    Set root = xml.documentElement 
     set xmlNodes = xml.selectNodes(xpath) 
      If xmlNodes.length > 0 then 
       For each x in xmlNodes 
        response.write(x.text) 
       Next 
      Else 
       response.write("not found.") 
      End if 
     set xmlNodes = nothing 
    Set root = Nothing 

Set xml = Nothing 

我已經在你的XML結構上測試了這個xpath,它似​​乎工作。有關xpath語法的更多信息是here

HTH, Erik

+0

當然!謝謝! – NinjaFart

相關問題