Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/315.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 从XmlDataSource填充DropDownList_C#_Asp.net_Xpath_Drop Down Menu - Fatal编程技术网

C# 从XmlDataSource填充DropDownList

C# 从XmlDataSource填充DropDownList,c#,asp.net,xpath,drop-down-menu,C#,Asp.net,Xpath,Drop Down Menu,我想使用一个简单的xml文件填充我的DropDownList: <?xml version="1.0" encoding="utf-8" ?> <Databases> <Database>foo</Database> <Database>bar</Database> <Database>baz</Database> </Databases> 我的下拉列表呈现为: <se

我想使用一个简单的xml文件填充我的DropDownList:

<?xml version="1.0" encoding="utf-8" ?>
<Databases>
  <Database>foo</Database>
  <Database>bar</Database>
  <Database>baz</Database>
</Databases>
我的下拉列表呈现为:

<select name="databaseDropDownList" id="databaseDropDownList"> 
                    <option selected="selected" value="System.Web.UI.WebControls.XmlDataSourceNodeDescriptor">System.Web.UI.WebControls.XmlDataSourceNodeDescriptor</option>
                    <option value="System.Web.UI.WebControls.XmlDataSourceNodeDescriptor">System.Web.UI.WebControls.XmlDataSourceNodeDescriptor</option>
                    <option value="System.Web.UI.WebControls.XmlDataSourceNodeDescriptor">System.Web.UI.WebControls.XmlDataSourceNodeDescriptor</option>
</select>

System.Web.UI.WebControl.XmlDataSourceNodeDescriptor
System.Web.UI.WebControl.XmlDataSourceNodeDescriptor
System.Web.UI.WebControl.XmlDataSourceNodeDescriptor
我应该如何提取文本


谢谢

我想不起来了,但我认为XmlDataSource中存在一个bug,它阻止您绑定到xml节点的值。它仅适用于属性。如果我错了,请纠正我。您需要对XML文件做一点小小的修改:

<%@ Page Language="C#" %>
<script runat="server">
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            string xml =
@"<?xml version=""1.0"" encoding=""utf-8"" ?>
<Databases>
  <Database name=""foo"" />
  <Database name=""bar"" />
  <Database name=""baz"" />
</Databases>";
            databasesSource.Data = xml;
            databasesSource.DataBind();
        }
    }
</script>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:DropDownList ID="databases" runat="server" DataSourceID="databasesSource" DataValueField="name" DataTextField="name" />
        <asp:XmlDataSource ID="databasesSource" runat="server" XPath="/Databases/Database" />
    </div>
    </form>
</body>
</html>

受保护的无效页面加载(对象发送方、事件参数e)
{
如果(!IsPostBack)
{
字符串xml=
@"
";
databasesSource.Data=xml;
databasesSource.DataBind();
}
}
无标题页

属性。这里有一种方法,您可以在LINQ查询中投影一个列表项数组:

XDocument doc = XDocument.Parse(@"<Databases>
        <Database>foo</Database>
        <Database>bar</Database>
        <Database>baz</Database>
    </Databases>");

YourList.Items.AddRange(
    (from XElement el in doc.Descendants("Database")
    select new ListItem(el.Value)).ToArray()
);
XDocument doc=XDocument.Parse(@)
福
酒吧
巴兹
");
YourList.Items.AddRange(
(来自文档子体(“数据库”)中的XElement el)
选择新列表项(el.Value)).ToArray()
);

我今天也有同样的问题。我的解决方案:

这是我的xml:

<?xml version="1.0" encoding="utf-8"?>

<pokemons>
  <pokemon>
    <nome itemname="bulbassaur">bulbassaur </nome>
  </pokemon>
  <pokemon>
    <nome itemname="charmander">chamander </nome>
  </pokemon>
  <pokemon>
    <nome itemname="squirtle"> squirtle </nome>
  </pokemon>
</pokemons>

巴龙
查曼德
斯奎特尔
我将DataTextField=“itemname”放在DropDownList服务器控件上。 例:


它的工作没有问题。可能不是最好的解决方案,。。。但至少比
System.Web.UI.WebControls.XmlDataSourceNodeDescriptor
要好

<?xml version="1.0" encoding="utf-8"?>

<pokemons>
  <pokemon>
    <nome itemname="bulbassaur">bulbassaur </nome>
  </pokemon>
  <pokemon>
    <nome itemname="charmander">chamander </nome>
  </pokemon>
  <pokemon>
    <nome itemname="squirtle"> squirtle </nome>
  </pokemon>
</pokemons>
<asp:DropDownList ID="DropDownList1" runat="server" AutoPostBack="True" 
            DataSourceID="XmlDataSource1" DataTextField="itemname">