C # - заполнить поле со списком DataTable - PullRequest
21 голосов
/ 02 ноября 2008

Я привык работать с Java, где доступно большое количество примеров. По разным причинам мне пришлось переключиться на C # и попытаться сделать в SharpDevelop следующее:

// Form has a menu containing a combobox added via SharpDevelop's GUI

// --- Variables
languages = new string[2];
languages[0] = "English";
languages[1] = "German";
DataSet myDataSet = new DataSet();

// --- Preparation
DataTable lTable = new DataTable("Lang");
DataColumn lName = new DataColumn("Language", typeof(string));
lTable.Columns.Add( lName );
for( int i=0; i<languages.Length; i++ ) {
    DataRow lLang = lTable.NewRow();
    lLang["Language"] = languages[i];
    lTable.Rows.Add(lLang);
}
myDataSet.Tables.Add(lTable);

// --- Handling the combobox
mnuActionLanguage.ComboBox.DataSource = myDataSet.Tables["Lang"].DefaultView;
mnuActionLanguage.ComboBox.DisplayMember = "Language";

Можно было бы увидеть некоторые значения в раскрывающемся списке, но он пуст. Пожалуйста, скажите мне, что я делаю не так; (

EDIT: mnuActionLanguage.ComboBox.DataBind () - это то, что я также нашел в сети, но в моем случае это не работает.

РЕШЕНИЕ

mnuActionLanguage.ComboBox.BindingContext = this.BindingContext;

в конце концов решил проблему!

Ответы [ 6 ]

30 голосов
/ 02 ноября 2008

Вам необходимо установить контекст привязки ToolStripComboBox.ComboBox.

Вот слегка измененная версия кода, который я только что воссоздал с помощью Visual Studio. Поле со списком пунктов меню в моем случае называется toolStripComboBox1. Обратите внимание на последнюю строку кода для установки контекста привязки.

Я заметил, что если комбо находится в видимой части панели инструментов, привязка работает без этого, но не в раскрывающемся списке. У тебя такая же проблема?

Если вы не можете заставить это работать, напишите мне на моей странице контактов, и я вышлю вам проект. Вы не сможете загрузить его с помощью SharpDevelop, но с помощью C # Express.

var languages = new string[2];
languages[0] = "English";
languages[1] = "German";

DataSet myDataSet = new DataSet();

// --- Preparation
DataTable lTable = new DataTable("Lang");
DataColumn lName = new DataColumn("Language", typeof(string));
lTable.Columns.Add(lName);

for (int i = 0; i < languages.Length; i++)
{
    DataRow lLang = lTable.NewRow();
    lLang["Language"] = languages[i];
    lTable.Rows.Add(lLang);
}
myDataSet.Tables.Add(lTable);

toolStripComboBox1.ComboBox.DataSource = myDataSet.Tables["Lang"].DefaultView;
toolStripComboBox1.ComboBox.DisplayMember = "Language";

toolStripComboBox1.ComboBox.BindingContext = this.BindingContext;
6 голосов
/ 14 апреля 2011
string strConn = "Data Source=SEZSW08;Initial Catalog=Nidhi;Integrated Security=True";
SqlConnection Con = new SqlConnection(strConn);
Con.Open();
string strCmd = "select companyName from companyinfo where CompanyName='" + cmbCompName.SelectedValue + "';";
SqlDataAdapter da = new SqlDataAdapter(strCmd, Con);
DataSet ds = new DataSet();
Con.Close();
da.Fill(ds);
cmbCompName.DataSource = ds;
cmbCompName.DisplayMember = "CompanyName";
cmbCompName.ValueMember = "CompanyName";
//cmbCompName.DataBind();
cmbCompName.Enabled = true;
3 голосов
/ 06 ноября 2016

Например, я создал таблицу:

DataTable dt = new DataTable ();
dt.Columns.Add("Title", typeof(string));
dt.Columns.Add("Value", typeof(int));

Добавить запись в таблицу:

DataRow row = dt.NewRow();
row["Title"] = "Price"
row["Value"] = 2000;
dt.Rows.Add(row);

или:

dt.Rows.Add("Price",2000);

наконец:

combo.DataSource = dt;
combo.DisplayMember = "Title";
combo.ValueMember = "Value";
2 голосов
/ 02 ноября 2008

Применяете ли вы RowFilter к вашему DefaultView позже в коде? Это может изменить возвращаемые результаты.

Я бы также не использовал строку в качестве элемента отображения, если у вас есть прямая ссылка на столбец данных, я бы использовал свойства объекта:

mnuActionLanguage.ComboBox.DataSource = lTable.DefaultView;
mnuActionLanguage.ComboBox.DisplayMember = lName.ColumnName;

Я пробовал это с пустой формой и стандартным комбо, и, кажется, работает для меня.

1 голос
/ 02 ноября 2008

Несколько баллов:

1) «DataBind ()» предназначен только для веб-приложений (не для приложений Windows).

2) Ваш код выглядит очень «JAVAish» (неплохая вещь, просто наблюдение).

Попробуйте это:

mnuActionLanguage.ComboBox.DataSource = languages;

Если это не сработает ... тогда я предполагаю, что ваш источник данных находится в другом месте кода.

0 голосов
/ 02 ноября 2008

Эта строка

mnuActionLanguage.ComboBox.DisplayMember = "Lang.Language";

неправильно. Измените его на

mnuActionLanguage.ComboBox.DisplayMember = "Language";

и это будет работать (даже без DataBind ()).

...