asp.net中详细信息视图中的下拉列表数据绑定

时间:2013-01-29 06:20:08

标签: c# asp.net

我有详细信息视图,用于编辑客户记录。在这个详细信息视图中,我有一个显示国家/地区列表的下拉列表。

我有一个名为CountryList的表格,它会将国家/地区列表填充到上面的下拉列表中。

用户可以毫无问题地编辑和保存数据。

但是,假设客户记录已将国家/地区选为“澳大利亚”,如果我从CountryList中删除澳大利亚并尝试在详细信息视图中编辑客户,则会收到以下错误。

SelectedValue which is invalid because it does not exist in the list of items

我知道原因是因为

SelectedValue='<%# Bind("Country") %>' 

并且无法在列表中找到它。

所以我的问题是,如何克服这个问题?

搜索网页后,我发现我可以覆盖数据绑定,但我不知道该怎么做。不知道如何覆盖,有人可以给我示例代码吗?

还有其他任何解决方案,例如在设置之前验证它吗?

谢谢。

2 个答案:

答案 0 :(得分:0)

在绑定之前尝试检查列表中的国家/地区是否存在(dataTable,DataSet等),例如

DataTable dtPs=getAvailableCountries();
string countryName = "Australia";
DataRow foundRow = dtPs.Rows.Find(countryName);
if(foundRow != null) {
 //You have it ...
 bindTheDropdown();
}else{
 //You dont have it ...
 dontBindTheDropdown();
}

答案 1 :(得分:0)

您可以在选择值之前调用函数,如下所示:

SelectedValue='<%# CheckCountry(Eval("Country"))%>'

在aspx.cs文件中创建如下函数,它将检查列表中是否存在国家/地区,如果不存在,则会显示默认值为

public string CheckCountry(string country)
{
   // add your logic to check contry in list 
   //  and return value as per result if it is exist
   // return country name else return default value
}