我编写了一段代码,实际上应该保存位于 recyclerview 中的 edittext 中的值:
@Override
public void onBindViewHolder(@NonNull NewRoomViewHolder holder, @SuppressLint("RecyclerView") int position) {
holder.newRoomText.setText(newRooms.get(position).getText());
holder.newRoomCount.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
onEditTextChanged(position, s.toString());
Toast toast = Toast.makeText(context,
String.valueOf(position), Toast.LENGTH_LONG);
toast.show();
}
@Override
public void afterTextChanged(Editable s) {
}
});
}
public void onEditTextChanged(int position, String charSeq) {
if (!Objects.equals(charSeq, "")) {
widgets.put("widget" + String.valueOf(position + 1), Integer.parseInt(charSeq));
}
}
然而,一些编辑文本已更新。将解释:
当用户在位置 1 的 edittext 中输入值时,onTextChanged函数会在以下位置调用:11, 14, 1(总共 15 个 edittext)。正确的位置总是最后出现的。那些。它不是将 1 中的值保存到列表中,而是保存 11、14。
有没有什么办法解决这一问题?
不幸的是,这是典型的回收者行为。
О проблеме
问题本身是 Recycler 的元素数量实际上是有限的。大约 = 屏幕上可见元素的数量 + 上方和下方 1-2 件库存。
当您滚动回收器时,这些元素将被重用(称为
onBindViewHolder
),因为
addTextChangedListener
- 这是向侦听器数组添加一个侦听器(它们在后台累积),然后会发生这种非标准行为。Решение классическое
addTextChangedListener 不是挂在方法中
onBindViewHolder
,而是挂在方法中onCreateViewHolder
onBindViewHolder
- 这是一个每次需要重绘元素时都会调用的方法,但onCreateViewHolder
它会被调用 1 次,并且一次为每个人调用。一般来说,即使
setOnClickListener
在onCreateViewHolder
Решение для варинтов "общего для всех Ресайклера"
有多种解决方案可以创建 1 个独特的适配器并为其配置不同的元素。但它们都有一个共同点——无法访问该方法
onCreateViewHolder
,即 我们只能访问它
onBindViewHolder
,但即使在这里,解决方案也很漂亮:
将对象创建
TextWatcher
为变量。和 中onBindViewHolder
,为您的EditText
挂起侦听器焦点。如果该字段处于焦点中 -
addTextChangedListener(myWatcher)
如果焦点被移除 -
removeTextChangedListener(myWatcher)