我有详细信息视图,用于编辑客户记录。在这个详细信息视图中,我有一个显示国家/地区列表的下拉列表。
我有一个名为CountryList的表格,它会将国家/地区列表填充到上面的下拉列表中。
用户可以毫无问题地编辑和保存数据。
但是,假设客户记录已将国家/地区选为“澳大利亚”,如果我从CountryList中删除澳大利亚并尝试在详细信息视图中编辑客户,则会收到以下错误。
SelectedValue which is invalid because it does not exist in the list of items
我知道原因是因为
SelectedValue='<%# Bind("Country") %>'
并且无法在列表中找到它。
所以我的问题是,如何克服这个问题?
搜索网页后,我发现我可以覆盖数据绑定,但我不知道该怎么做。不知道如何覆盖,有人可以给我示例代码吗?
还有其他任何解决方案,例如在设置之前验证它吗?
谢谢。
答案 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
}