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

本文关键字:net 视图 asp 数据绑定 下拉列表 详细信息 | 更新日期: 2023-09-27 17:56:31

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

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

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

但是,假设客户记录将国家/地区

选为"澳大利亚",如果我从国家/地区列表中删除澳大利亚并尝试在详细信息视图中编辑客户,则会出现以下错误。

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

我知道原因,因为

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

并且在列表中找不到它。

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

搜索网络后,我发现我可以覆盖数据绑定,但我不确定如何做到这一点。不知道如何覆盖,有人可以给我示例代码吗?

还有没有其他解决方案,例如在设置之前对其进行验证?

谢谢。

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

您可以在

选择值之前调用函数,如下所示:

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
}

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

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();
}