如何根据组合框选择更改列表框的内容
本文关键字:列表 选择 何根 组合 | 更新日期: 2023-09-27 17:59:22
我有一个WFA,用于动态恢复数据库。现在我有一个列表框,显示目录中的所有备份,但它也包含我想要访问的文件夹。下面是列表框的代码:
private void PopulateListBox()
{
try
{
var dinfo = new DirectoryInfo(@"C:'Program Files'Microsoft SQL Server'MSSQL11.MSSQLSERVER'MSSQL'Backup");
var files = dinfo.GetFiles("*.bak");
foreach (var file in files)
{
listBox1.Items.Add(file.Name);
}
}
catch (Exception)
{
MessageBox.Show("The application could not find the directory to populate the List Box.");
}
}
目前,我设置了一个组合框来显示备份中的不同文件夹:
private void PopulateComboBox()
{
string[] directory = Directory.GetDirectories(@"C:'Program Files'Microsoft SQL Server'MSSQL11.MSSQLSERVER'MSSQL'Backup");
foreach (string folder in directory)
{
comboBox1.Items.Add(folder);
}
}
当我从组合框中单击不同的目录时,我要做的是更改列表框的内容。我创建了一个方法来实现我想要做的事情,但我不确定如何编码
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
listbox1.Clear()
//rest of the code would go here
}
如何根据组合框中的选择在列表框中显示每个目录的内容?
我更喜欢WPF,但我很确定它在这里的工作方式也是一样的。
您希望处理其中一个"SelectionChanged"事件(SelectedIndexChanged、SelectedValueChanged或SelecitonChangeCommitted),并在处理程序中放入代码,以检查在组合框中选择了什么项目,并根据该选择重新填充列表框。
这应该可以工作。
a) 使populateListBox函数接受参数"dinfo"
private void PopulateListBox(string dname)
{
try
{
listBox1.Clear();
var dinfo = new DirectoryInfo(@"C:'Program Files'Microsoft SQL Server'MSSQL11.MSSQLSERVER'MSSQL'Backup'" + dname); //combine base folder with the folder from combobox
var files = dinfo.GetFiles("*.bak");
foreach (var file in files)
{
listBox1.Items.Add(file.Name);
}
}
catch (Exception)
{
MessageBox.Show("The application could not find the directory to populate the List Box.");
}
}
b) 在选定的dexchanged方法中,将组合框中的选定值传递到PopulateListBox函数中:
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
PopulateListBox(comboBox1.SelectedValue);
}
我最终根据Yushatak的回应提出了自己的解决方案。我创建了一个指向备份文件夹的全局字符串变量(这是应用程序启动时的默认目录),在组合框UI的属性中创建了一组集合,删除了我创建的组合框函数(因为不再需要它),然后在SelectionIndexChanged方法中使用了一系列If语句来处理我想要访问的文件夹。
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
if (comboBox1.SelectedItem == "Backup")
{
string backup = @"C:'Program Files'Microsoft SQL Server'MSSQL11.MSSQLSERVER'MSSQL'Backup";
PopulateListBox(backup);
}
else if (comboBox1.SelectedItem == "Backups 2")
{
string backup = @"C:'Program Files'Microsoft SQL Server'MSSQL11.MSSQLSERVER'MSSQL'Backup'Backups 2";
PopulateListBox(backup);
}
else if (comboBox1.SelectedItem == "Backups 3")
{
string backup = @"C:'Program Files'Microsoft SQL Server'MSSQL11.MSSQLSERVER'MSSQL'Backup'Backups 3";
PopulateListBox(backup);
}
}