C # - Заполните поле со списком параметром DataTable
-
05-07-2019 - |
Вопрос
Я привык работать с 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";
Можно было бы предположить, что в выпадающем списке отображаются некоторые значения, но он пуст.Пожалуйста, скажите мне, что я делаю не так;(
Редактировать:mnuActionLanguage.ComboBox.DataBind() - это то, что я также нашел в сети, но в моем случае это не работает.
РЕШЕНИЕ
mnuActionLanguage.ComboBox.BindingContext = this.BindingContext;
в конце концов проблему решили!
Решение
Вам необходимо установить контекст привязки ToolStripComboBox.ComboBox.
Вот слегка измененная версия кода, который я только что воссоздал с помощью Visual Studio.Поле со списком пункта меню в моем случае называется toolStripComboBox1.Обратите внимание на последнюю строку кода, чтобы задать контекст привязки.
Я заметил, что если комбо находится в видимом поле toolstrip, привязка работает без этого, но не тогда, когда оно находится в выпадающем списке.У вас такая же проблема?
Если у вас не получается заставить это работать, напишите мне через мою страницу контактов, и я отправлю вам проект.Вы не сможете загрузить его с помощью 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;
Другие советы
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;
Например, я создал таблицу :
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";
Применяете ли вы RowFilter к вашему DefaultView позже в коде?Это может изменить возвращаемые результаты.
Я бы также не стал использовать строку в качестве элемента отображения, если у вас есть прямая ссылка на столбец данных, я бы использовал свойства объекта:
mnuActionLanguage.ComboBox.DataSource = lTable.DefaultView;
mnuActionLanguage.ComboBox.DisplayMember = lName.ColumnName;
Я пробовал это с пустой формой и стандартной комбинацией, и, кажется, у меня это работает.
Несколько моментов:
1) "DataBind()" предназначен только для веб-приложений (не для приложений Windows).
2) Ваш код выглядит очень "JAVAish" (неплохая вещь, просто наблюдение).
Попробуй это:
mnuActionLanguage.ComboBox.DataSource = languages;
Если это не сработает...тогда я предполагаю, что на ваш источник данных наступают где-то в другом месте кода.
Эта линия
mnuActionLanguage.ComboBox.DisplayMember = "Lang.Language";
это неправильно.Измените его на
mnuActionLanguage.ComboBox.DisplayMember = "Language";
и это будет работать (даже без DataBind()).