Как вернуть выбранные элементы обратно в selectedListBox
Я проверил список списков вызовов CLB_CONTROLLER, который загружается на страницу для отображения имен вместо идентификатора: эта информация хранится в dbo.CHIPSET
public void loadCategory()
{
CLB_CONTROLLER.DataSource = catg.getCategories();
CLB_CONTROLLER.DisplayMember = "CHIPSET";
CLB_CONTROLLER.ValueMember = "CHIPSET_ID";
}
Тогда я бы вставил данные в БД в виде строки. Эта информация хранится в dbo.MYDB
//LOOP THROUGH CONTROLLER CHECKED ITEMS TO INSERT ALL SELECTED
string chip = "";
for (int i = 0; i < CLB_CONTROLLER.CheckedItems.Count; i++)
{
if (chip == "")
{
chip = CLB_CONTROLLER.GetItemText(CLB_CONTROLLER.CheckedItems[i]);
}
else
{
chip += ", " + CLB_CONTROLLER.GetItemText(CLB_CONTROLLER.CheckedItems[i]);
}
}
Пока все хорошо... Теперь я хочу создать функцию обновления... Когда пользователь выбирает ячейку из DataGrid
Хочу автозаполнить все textboxes
, CheckBoxes
и т.д. на странице. Поэтому я пытаюсь понять, как я могу сделать это с CLB_CONTROLLER
упомянутое выше. Обновление смотрит внутрь dbo.MYDB
и столбец 2 CHIPSET
которая теперь является строкой (вставлена с кодом выше). У меня есть этот код ниже, но когда я нажимаю на DataGrid
внутри ничего не происходит CLB_CONTROLLER
//CHECK IF CONTROLLER CONTAINES CONTENT, THEN SELLECT APPROPRIATE CHECK BOX
string con = DGV_AOC.CurrentRow.Cells[2].Value.ToString();
string[] convalues = con.Split(',');
for (int i = 0; i < convalues.Length; i++)
{
convalues[i] = convalues[i].Trim();
}
for (int i = 0; i < CLB_CONTROLLER.Items.Count; i++)
{
CLB_CONTROLLER.SetItemChecked(i, false);//First uncheck the old value!
for (int x = 0; x < convalues.Length; x++)
{
if (CLB_CONTROLLER.Items[i].ToString() == convalues[x].ToString())
{
//Check only if they match!
CLB_CONTROLLER.SetItemChecked(i, true);
}
}
}
Любая помощь будет принята с благодарностью.
1 ответ
Допустим, вы заполнили CheckedListBox
с a,b,c,d,e,f
например, как тексты предметов.
Затем вы можете установить отмеченные элементы на основе списка через запятую следующим образом:
var itemsToSelect = "a,c,d";
var items = itemsToSelect.Split(',');
for (var i = 0; i < checkedListBox1.Items.Count; i++)
{
var b = items.Contains(checkedListBox1.GetItemText(checkedListBox1.Items[i]));
checkedListBox1.SetItemChecked(i, b);
}
Также вы можете получить отмеченные элементы в строке через запятую следующим образом:
var selectedItems = string.Join(",",
checkedListBox1.CheckedItems.Cast<object>()
.Select(x => checkedListBox1.GetItemText(x)));