0
我有一些代碼是爲了遞歸構建XML而編寫的,除了一件事情之外,它的工作原理非常好,不是那麼通用。優化遞歸XML構建
數組是
string[] countries= string[]{ ..... }
我的主意,有跟隨,如果一個數組只包含一個字符串比它應該是:
<Where>
<Eq>
<FieldRef />
<Value />
</Eq>
</Where>
如果有一個以上的,比它應該包含<OR>
,但對於最後一個字符串值應該在相同的OR中:所以基本上它會是這樣的4項:
<Where>
<Or>
<Eq>
<FieldRef Name="Title" />
<Value Type="Text">Canada</Value>
</Eq>
<Or>
<Eq>
<FieldRef Name="Title" />
<Value Type="Text">New Zealand</Value>
</Eq>
<Or>
<Eq>
<FieldRef Name="Title" />
<Value Type="Text">United States</Value>
</Eq>
<Eq>
<FieldRef Name="Title" />
<Value Type="Text">Switzerland</Value>
</Eq>
</Or>
</Or>
</Or>
</Where>
一切都嵌套。
這裏是我的代碼,它的多陣列而不是一個結果的偉大工程:
private XElement Recursion(XElement parentElement, int counter)
{
if (counter == 0)
{
return parentElement;
}
XElement orElement = new XElement("Or");
XElement eqElement = new XElement("Eq");
XElement fieldElement = new XElement("FieldRef");
XAttribute nameAttribute = new XAttribute("Name", "Title");
fieldElement.Add(nameAttribute);
XElement valueElement = new XElement("Value", Countries[counter]);
XAttribute typeAttribute = new XAttribute("Type", "Text");
valueElement.Add(typeAttribute);
eqElement.Add(fieldElement);
eqElement.Add(valueElement);
orElement.Add(eqElement);
if (counter == 1)
{
eqElement = new XElement("Eq");
valueElement = new XElement("Value", Countries[0]);
valueElement.Add(typeAttribute);
eqElement.Add(fieldElement);
eqElement.Add(valueElement);
orElement.Add(eqElement);
}
XElement lastOrElement = parentElement.Descendants("Or").FirstOrDefault(or => !or.Descendants("Or").Any());
if (lastOrElement == null)
{
parentElement.Add(orElement);
}
else
{
lastOrElement.Add(orElement);
}
return Recursion(parentElement, --counter);
}
}