1

顧客レコードの編集に使用される詳細ビューがあります。この詳細ビュー内に、国のリストを表示するドロップダウン リストがあります。

上記のドロップダウンリストに国のリストを入力する CountryList というテーブルがあります。

ユーザーは問題なくデータを編集および保存できます。

ただし、顧客レコードで国が「オーストラリア」として選択されていると仮定し、CountryList からオーストラリアを削除して、詳細ビュー内で顧客を編集しようとすると、以下のエラーが発生します。

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

理由はわかっているので、

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

そしてそれはリストでそれを見つけることができません。

だから私の質問は、この問題をどのように克服するのですか?

Web を検索した後、Databind をオーバーライドできることがわかりましたが、これを行う方法がわかりません。オーバーライドする方法がわかりません。誰かサンプルコードを教えてください。

また、設定前に検証するなど、これに対する他の解決策はありますか?

ありがとうございました。

4

2 に答える 2

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();
}
于 2013-01-29T06:34:33.300 に答える
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
}
于 2013-01-29T06:35:13.893 に答える