Asp.net GridView不将LINQ刷新为XML数据?
如果有一个包含3个条目的Xml文件 国家名称=丹麦国际互联网LD=dk 国家名称=Holland InternetTLD=nl 国家名称=英国国际互联网名称=英国 在我的网页中,如果有文本框、gridview和xmlDataSource。 当我没有在文本框中指定任何内容时,所有三个国家都将使用LINQ查询加载到xmlDataSource中,然后显示在gridview中。 但是,当我在文本框中指定例如“Denmark”时,我会继续查看所有3条记录,而LINQ查询的count属性表示1,xmlDataSource的Data属性仅显示1个国家以及丹麦 问题是gridView似乎没有刷新新数据 这是我的密码:Asp.net GridView不将LINQ刷新为XML数据?,asp.net,gridview,linq-to-xml,Asp.net,Gridview,Linq To Xml,如果有一个包含3个条目的Xml文件 国家名称=丹麦国际互联网LD=dk 国家名称=Holland InternetTLD=nl 国家名称=英国国际互联网名称=英国 在我的网页中,如果有文本框、gridview和xmlDataSource。 当我没有在文本框中指定任何内容时,所有三个国家都将使用LINQ查询加载到xmlDataSource中,然后显示在gridview中。 但是,当我在文本框中指定例如“Denmark”时,我会继续查看所有3条记录,而LINQ查询的count属性表示1,xmlDat
protected void Page_Load(object sender, EventArgs e)
{
QueryXml();
} // Page_Load()
private void QueryXml()
{
XElement _countries = XElement.Load(Server.MapPath(COUNTRIES_XML));
IEnumerable<XElement> query = null;
// extract all countries
if (txtCountry.Text == "" || txtCountry.Text == "*")
{
query = from c in _countries.Elements()
select c;
}
else
{
// Extract all elements where Name has been specified
query = from c in _countries.Elements()
where c.Attribute("Name").Value.ToString().StartsWith(txtCountry.Text, StringComparison.CurrentCultureIgnoreCase)
select c;
}
// Set xml filtered string data source
xmlDsCountries.Data =
"<Countries>" +
string.Join("", query.Select(country => country.ToString())) +
"</Countries>";
// set the data source of the gridview
gdvwCountries.DataSource = xmlDsCountries;
// Show the data
gdvwCountries.DataBind();
lblMsg.Text = query.Count().ToString();
} // QueryXml()
为什么gridView没有刷新
多谢各位
Chris尝试关闭XmlDataSource上的缓存
protected void Page_Load(object sender, EventArgs e)
{
xmlDsCountries.EnableCaching = false;
//...........the rest.............
}