developer tip

사전을 데이터 소스로 사용하는 C # DropDownList

optionbox 2020. 8. 9. 10:22
반응형

사전을 데이터 소스로 사용하는 C # DropDownList


나는 설정할 DataTextFieldDataValueFieldDropdownlist의 사전 (목록)을 사용하여 (languageList) languageCod화면에 텍스트로 키와 언어 이름 (영어)으로 (EN-GB)의.

관련 코드 :

string[] languageCodsList= service.LanguagesAvailable();
Dictionary<string, string> list = 
                   new Dictionary<string, string>(languageCodsList.Length);

foreach (string cod in languageCodsList)
{
    CultureInfo cul = new CultureInfo(cod);
    list.Add(cod, cul.DisplayName);
}
languageList.DataSource = list;
languageList.DataBind();

어떻게 설정 DataTextField하고 DataValueField?


마찬가지로 "Key"및 "Value"텍스트를 사용하여 DropDownList의 DataTextField 및 DataValueField를 설정할 수 있습니다.

    Dictionary<string, string> list = new Dictionary<string, string>();
    list.Add("item 1", "Item 1");
    list.Add("item 2", "Item 2");
    list.Add("item 3", "Item 3");
    list.Add("item 4", "Item 4");

    ddl.DataSource = list;
    ddl.DataTextField = "Value";
    ddl.DataValueField = "Key";
    ddl.DataBind();

사전 열거되면 얻을 것입니다 KeyValuePair<TKey,TValue>그냥 "값"을위한 "키"를 지정해야합니다 ... 그래서 객체 DataTextFieldDataValueField선택에 각각 / 속성을.

Joe의 의견 덕분에 나는 올바른 방법을 찾기 위해 질문을 다시 읽었습니다. 일반적으로 사전에있는 "키"는 표시되는 텍스트이고 "값"은 가져온 값이 될 것으로 예상합니다. 샘플 코드는 다른 방식으로 사용합니다. 이런 식으로 실제로 필요하지 않는 한 코드를 다음과 같이 작성하는 것이 좋습니다.

list.Add(cul.DisplayName, cod);

( 물론에 "키"를 사용 DataTextField하고 "값" 을 사용하도록 바인딩을 변경합니다 DataValueField.)

사실 사전이 아닌 목록을 원하는 것 같기 때문에 처음부터 사전을 사용하는 것을 다시 고려할 수 있습니다. 다음을 사용할 수 있습니다 List<KeyValuePair<string, string>>.

string[] languageCodsList = service.LanguagesAvailable();
var list = new List<KeyValuePair<string, string>>();

foreach (string cod in languageCodsList)
{
    CultureInfo cul = new CultureInfo(cod);
    list.Add(new KeyValuePair<string, string>(cul.DisplayName, cod));
}

또는 일반 CultureInfo목록을 사용하십시오 . LINQ는이 작업을 정말 쉽게 만듭니다.

var cultures = service.LanguagesAvailable()
                      .Select(language => new CultureInfo(language));
languageList.DataTextField = "DisplayName";
languageList.DataValueField = "Name";
languageList.DataSource = cultures;
languageList.DataBind();

If you're not using LINQ, you can still use a normal foreach loop:

List<CultureInfo> cultures = new List<CultureInfo>();
foreach (string cod in service.LanguagesAvailable())
{
    cultures.Add(new CultureInfo(cod));
}
languageList.DataTextField = "DisplayName";
languageList.DataValueField = "Name";
languageList.DataSource = cultures;
languageList.DataBind();

If the DropDownList is declared in your aspx page and not in the codebehind, you can do it like this.

.aspx:

<asp:DropDownList ID="ddlStatus" runat="server" DataSource="<%# Statuses %>"
     DataValueField="Key" DataTextField="Value"></asp:DropDownList>

.aspx.cs:

protected void Page_Load(object sender, EventArgs e)
{
    ddlStatus.DataBind();
    // or use Page.DataBind() to bind everything
}

public Dictionary<int, string> Statuses
{
    get 
    {
        // do database/webservice lookup here to populate Dictionary
    }
};

Just use "Key" and "Value"

참고URL : https://stackoverflow.com/questions/805595/c-sharp-dropdownlist-with-a-dictionary-as-datasource

반응형