我认为我做错了,但我有一个 RecyclerView 适配器和简单的按钮点击(在本例中是一个 LinearLayout
)触发以下
this.NotifyItemRemoved(position);
完整的按钮代码如下
public override RecyclerView.ViewHolder OnCreateViewHolder(ViewGroup parent, int viewType)
{
..........
LinearLayout _ARC = V.FindViewById<LinearLayout>(Resource.Id.moreArc);
_ARC.Click += async delegate {
try
{
Log.Info("101029", "ARC_Clicked");
await usersAct.SWITCH_ARCHIVE(ID); // some user action
this.NotifyItemRemoved(position);
}
catch (Exception X)
{
Log.Info("101029", "ERROR AT ARC_Clicked: " + X.Message);
}
};
.......
}
这工作正常并且项目被很好地删除,但是当我在 recyclerview
中向下滚动并返回到项目被删除的位置时,项目又出现了。
我认为我做错了或者我的逻辑不正确?有什么想法吗?
最佳答案
NotifyItemRemoved
仅 将其从显示中删除(如果显示或在其 View 缓存中)并导致其他屏幕元素/ View 移动(动画),您还需要实际删除支持数据从您的适配器中存储它。
例如,我有一个 RecyclerView.Adapter
将其数据存储为 ObservableCollection<SomeClass>
的子类在名为 myDataCollection
的实例变量中在适配器内。
在适配器的初始化中(对我来说是.ator
),我注册了一个CollectionChanged
。 ObservableCollection
上的 Activity 我传递给构造函数,即:
myDataCollection.CollectionChanged += CollectionChanged;
我的适配器子类中的事件定义为:
void CollectionChanged(object sender, NotifyCollectionChangedEventArgs e)
{
switch (e.Action)
{
case NotifyCollectionChangedAction.Add:
NotifyItemRangeInserted(e.NewStartingIndex, e.NewItems.Count);
break;
case NotifyCollectionChangedAction.Remove:
NotifyItemRangeRemoved(e.OldStartingIndex, e.OldItems.Count);
break;
case NotifyCollectionChangedAction.Move:
NotifyItemMoved(e.OldStartingIndex, e.NewStartingIndex);
break;
case NotifyCollectionChangedAction.Replace:
case NotifyCollectionChangedAction.Reset:
NotifyAll();
break;
}
}
现在我随时更改 ObservableCollection
,适配器会收到更改通知并更新 RecyclerView
这就是观察。
现在您可以让您更改添加/删除/移动到只是 ObservableCollection
和 RecyclerView
是“自动神奇地”更新。
如果您最终使用 Filter
,这也有效在您的适配器中实现搜索功能 RecyclerView
.
注意:如果 ObservableCollection
中对象的属性,这不会更新 RecyclerView 中的膨胀 View 更改,但这可以通过 PropertyChangedEventHandler
完成如果需要,在你的对象上......
关于android - RecyclerView Adapter - NotifyItemRemoved - 删除的项目在滚动后再次出现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50691177/