[英]C# WPF ListView not deleting items properly
我有一个看起来像这样的ListView
;
<Window x:Class="WPF_Viewer.URLLinks"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:WPF_Viewer"
mc:Ignorable="d"
Title="URLLinks" Height="461.215" Width="606.542" WindowStartupLocation="CenterScreen">
<Grid>
<ListView x:Name="proxyListView" Loaded="proxyListView_Loaded">
<ListView.ContextMenu>
<ContextMenu Name="contextMenu1">
<MenuItem Name="item1" Header="Delete" Click="item1_Click"/>
</ContextMenu>
</ListView.ContextMenu>
</ListView>
</Grid>
</Window>
我正在尝试添加一个ContextMenu
来删除SelectedItem
。
public partial class URLLinks : Window
{
public URLLinks()
{
InitializeComponent();
}
private void proxyListView_Loaded(object sender, RoutedEventArgs e)
{
proxyListView.ItemsSource = GlobalVars.URLLinks;
}
private void item1_Click(object sender, RoutedEventArgs e)
{
GlobalVars.URLLinks.RemoveAt(proxyListView.SelectedIndex);
ICollectionView view = CollectionViewSource.GetDefaultView(proxyListView.ItemsSource);
//view.Refresh();
}
}
有任何想法吗?
编辑:这是变量及其设置方式
public static async void GetLink(string url)
{
try
{
string sURL = url;
Uri uri = new Uri(sURL);
string host = uri.Host;
using (HttpClient clientduplicate = new HttpClient())
{
clientduplicate.DefaultRequestHeaders.Add("User-Agent",
"Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident / 6.0)");
using (HttpResponseMessage responseduplicate = await clientduplicate.GetAsync(sURL))
{
using (HttpContent contentduplicate = responseduplicate.Content)
{
try
{
string resultduplicate = await contentduplicate.ReadAsStringAsync();
var websiteduplicate = new HtmlAgilityPack.HtmlDocument();
websiteduplicate.LoadHtml(resultduplicate);
List<string> ListItems = new List<string>();
Settings.Default.Reload();
int maxLinks = Convert.ToInt32(Math.Round(Convert.ToDouble(Settings.Default["subLinksValue"]) * 10));
foreach (HtmlNode links in websiteduplicate.DocumentNode.SelectNodes("//a[@href]"))
{
HtmlAttribute att = links.Attributes["href"];
foreach (var link in att.Value.Split(' '))
{
if (ListItems.Count >= maxLinks)
{
GlobalVars.URLLinks = ListItems;
//File.WriteAllLines(AppDomain.CurrentDomain.BaseDirectory + @"\links.txt", ListItems.ToArray());
return;
}
if (link.StartsWith("http") && link.Contains(host) && CheckURLValid(link))
{
ListItems.Add(link);
}
}
}
GlobalVars.URLLinks = ListItems;
//File.WriteAllLines(AppDomain.CurrentDomain.BaseDirectory + @"\links.txt", ListItems.ToArray());
//return ListItems;
}
catch (Exception ex1)
{
Console.WriteLine("Error getting links");
//return null;
}
}
}
}
}
catch (Exception ex)
{
System.Windows.MessageBox.Show("Error, url not formatted correctly. Try coping your url from your browser");
}
}
即使您不打算走完整的MVVM路线,也至少要使用ObservableCollection的项,并为其分配ListView的ItemSource。 删除或添加项目时,这将自动更新控件。
试图在UI控件上执行业务逻辑操作将很快沦为一大堆意大利面条。
如果GlobalVars.URLLinks
返回ObservableCollection<T>
或实现INotifyCollectionChanged
接口的任何其他自定义类型,则它将起作用:
private void item1_Click(object sender, RoutedEventArgs e)
{
var ic = proxyListView.ItemsSource as IList<string>;
ic.RemoveAt(proxyListView.SelectedIndex);
}
但是,如果在删除项目时,源集合没有引发更改通知(而List<T>
没有),则在删除项目后,必须重新设置ItemsSource
属性以刷新ListView
:
private void item1_Click(object sender, RoutedEventArgs e)
{
GlobalVars.URLLinks.RemoveAt(proxyListView.SelectedIndex);
proxyListView.ItemsSource = GlobalVars.URLLinks;
}
为了使它起作用,我唯一要做的就是将您的集合从List<string>
更改为ObservableCollection<string>
。
完成此操作后,您无需重置列表视图上的项目。
static ObservableCollection<string> items = new ObservableCollection<string>() { "Item 1", "Item 2" };
private void proxyListView_Loaded(object sender, RoutedEventArgs e)
{
proxyListView.ItemsSource = items;
}
private void item1_Click(object sender, RoutedEventArgs e)
{
items.RemoveAt(proxyListView.SelectedIndex);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.