- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Kotlin 查看 RecyclerView 中的列表。我正在 fragment 类中编写 RecyclerView id 并在适配器中设置列表(响应),但它没有显示在 RecyclerView 中。下面写了代码,我不知道如何解决这个问题。
项目有一个 Fragment、Adapter、xml 文件和模型类。
fragment_availabletender
此页面有 RecyclerView。
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools">
<!-- Data to make available to the XML via data binding. In this case,
the whole ViewModel, so that we can access the LiveData,
click handlers, and state variables. -->
<data>
<variable
name="viewModel"
type= "com.bitcomm.main.ui.home.NotificationViewModel" />
</data>
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.appcompat.widget.AppCompatSpinner
android:id="@+id/spinner2"
android:layout_width="93dp"
android:layout_height="39dp"
android:layout_alignParentRight="true"
android:entries="@array/array_name"
style="@style/spinnerItemStyle"
android:layout_alignParentEnd="true" />
<androidx.appcompat.widget.AppCompatSpinner
android:id="@+id/spinner1"
android:layout_width="93dp"
android:layout_height="39dp"
android:layout_toLeftOf="@+id/spinner2"
android:entries="@array/array_name1"
style="@style/spinnerItemStyle"
android:layout_toStartOf="@+id/spinner2" />
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/tender_list"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#0f3b52"
android:color="@color/cardview_light_background"
android:padding="6dp"
android:layout_below="@+id/spinner2"
app:layoutManager="androidx.recyclerview.widget.LinearLayoutManager"
/>
</RelativeLayout>
模型类这个类有模型
data class TenderProperty(
val id: String,
// used to map img_src from the JSON to imgSrcUrl in our class
@Json(name = "img_src") val imgSrcUrl: String,
val type: String,
val price: Double
)
TenderViewModel这里的回应越来越多
private val _response = MutableLiveData<List<TenderProperty>>()
// The external immutable LiveData for the response String
val response: LiveData<List<TenderProperty>>
get() = _response
private val _navigateToSelectedProperty = MutableLiveData<TenderProperty>()
val navigateToSelectedProperty: LiveData<TenderProperty>
get() = _navigateToSelectedProperty
// Create a Coroutine scope using a job to be able to cancel when needed
private var viewModelJob = Job()
// the Coroutine runs using the Main (UI) dispatcher
private val coroutineScope = CoroutineScope(viewModelJob + Dispatchers.Main )
/**
* Call getMarsRealEstateProperties() on init so we can display status immediately.
*/
init {
getTenderRealEstateProperties()
}
private fun getTenderRealEstateProperties() {
coroutineScope.launch {
// Get the Deferred object for our Retrofit request
var getPropertiesDeferred = TenderApi.retrofitService.getProperties()
try {
// this will run on a thread managed by Retrofit
val listResult = getPropertiesDeferred.await()
_sortByPrice.value=listResult.toList().sortedBy {it.price}
_sortById.value=listResult.toList().sortedBy {it.id}
_response.value = listResult
println("hii"+_response.value)
Log.d("class","_response.value")
} catch (e: Exception) {
_response.value = ArrayList()
Log.d("class","_response.value")
}
}
}
fun displayPropertyDetails(marsProperty: TenderProperty) {
_navigateToSelectedProperty.value = marsProperty
}
fun displayPropertyDetailsComplete() {
_navigateToSelectedProperty.value = null
}
ListTenderAdapter这是适配器类
class ListTenderAdapter( private val onClickListener: OnClickListener ) :
ListAdapter<TenderProperty,
ListTenderAdapter.TenderPropertyViewHolder>(DiffCallback) {
class TenderPropertyViewHolder(private var binding:TenderListViewBinding):
RecyclerView.ViewHolder(binding.root) {
fun bind(tenderProperty: TenderProperty) {
binding.property = tenderProperty
// This is important, because it forces the data binding to execute immediately,
// which allows the RecyclerView to make the correct view size measurements
binding.executePendingBindings()
}
}
/**
* Allows the RecyclerView to determine which items have changed when the [List] of [MarsProperty]
* has been updated.
*/
companion object DiffCallback : DiffUtil.ItemCallback<TenderProperty>() {
override fun areItemsTheSame(oldItem: TenderProperty, newItem: TenderProperty): Boolean {
return oldItem === newItem
}
override fun areContentsTheSame(oldItem: TenderProperty, newItem: TenderProperty): Boolean {
return oldItem.id == newItem.id
}
}
/**
* Create new [RecyclerView] item views (invoked by the layout manager)
*/
override fun onCreateViewHolder(parent: ViewGroup,
viewType: Int): TenderPropertyViewHolder {
return TenderPropertyViewHolder(TenderListViewBinding.inflate(LayoutInflater.from(parent.context)))
}
/**
* Replaces the contents of a view (invoked by the layout manager)
*/
override fun onBindViewHolder(holder: TenderPropertyViewHolder, position: Int) {
val tenderProperty = getItem(position)
holder.itemView.setOnClickListener {
onClickListener.onClick(tenderProperty)
}
holder.bind(tenderProperty)
}
/**
* Custom listener that handles clicks on [RecyclerView] items. Passes the [MarsProperty]
* associated with the current item to the [onClick] function.
* @param clickListener lambda that will be called with the current [MarsProperty]
*/
class OnClickListener(val clickListener: (tenderProperty: TenderProperty) -> Unit) {
fun onClick(tenderProperty: TenderProperty) = clickListener(tenderProperty)
}
}
这是 Fragment 类
class TenderListFragment : Fragment() {
private val viewModel: NotificationViewModel by lazy {
ViewModelProviders.of(this).get(NotificationViewModel::class.java)
}
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
val binding = FragmentAvailabletenderBinding.inflate(inflater)
binding.lifecycleOwner = this
binding.viewModel = viewModel
binding.tenderList.addItemDecoration(MarginItemDecoration(5))
val adapter=binding.tenderList.adapter as ListTenderAdapter
adapter.submitList(viewModel.response.value)
binding.tenderList.adapter = ListTenderAdapter(ListTenderAdapter.OnClickListener {
viewModel.displayPropertyDetails(it)
})
adapter.notifyDataSetChanged()
// binding.tenderList.layoutManager = LinearLayoutManager(activity)
setHasOptionsMenu(true)
return binding.root
}
最佳答案
在 onCreateView 内的 TenderListFragment 类中删除以下所有行:
binding.tenderList.addItemDecoration(MarginItemDecoration(5))
val adapter=binding.tenderList.adapter as ListTenderAdapter
adapter.submitList(viewModel.response.value)
binding.tenderList.adapter = ListTenderAdapter(ListTenderAdapter.OnClickListener {
viewModel.displayPropertyDetails(it)
})
adapter.notifyDataSetChanged()
将适配器声明为TenderListFragment内的全局变量
private lateinit var adapter : ListTenderAdapter
并从onCreateView()
调用此方法
private fun setupRecyclerView(){
binding.tenderList.addItemDecoration(MarginItemDecoration(5))
adapter = ListTenderAdapter(ListTenderAdapter.OnClickListener {
viewModel.displayPropertyDetails(it)
})
binding.tenderList.setAdapter(adapter)
}
再添加一个方法 initViewModel()
,并在 setupRecyclerView()
之后从 onCreateView
调用此方法。
private fun initViewModel(){
viewModel.response.observe(this, Observer {
adapter.submitList(it)
})
}
关于java - RecyclerView 未获取列表(响应),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59999832/
我在另一个 RecyclerView(parentRecyclerView) 中实现了 RecyclerView(childRecyclerView),图片说明了所有的实现: 我想编写一个 espre
我正在构建一个应用程序,它使用ViewPager2在页面之间水平滚动,每个页面都有一个垂直滚动的内容RecyclerView,其中每个列表的第一个位置都有一行水平滚动小部件,例如附加到寻呼机指示器类型
我正在尝试实现一个水平的 recyclerview 并且 recyclerview 的每个项目都将是一个具有网格布局的垂直 recyclerview。我面临的问题是,当我尝试垂直滚动子 recycle
我使用显示条目列表的 RecyclerView。每个条目都托管另一个 RecyclerView,它是一个图像列表。 我现在想让这个嵌套的 RecyclerView 可点击,而不是它的项目,而是整个 V
我正在尝试将手机中的图像加载到我的回收 View 中。 到目前为止,我已经创建了一个 recyclerview.adapter 和一个 gridlayoutmanager,并将它们附加到我的 recy
我需要一个可扩展 View ,其中父/可扩展标题将具有文本和下拉箭头。每个此类标题的子项应该是在网格结构中具有多个项目的 View 。 (有点像带有 GridLayoutManager 的回收器 Vi
我正在使用显示不同类别列表的 RecyclerView。每行项目还包含 RecyclerView 以显示类别项目列表。父级 RecyclerView 由垂直 LinearLayoutManager 填
我正在更新一个旧的 Android 项目,现在我从 RecyclerView 中反复收到这条日志语句: W/RecyclerView:RecyclerView 不支持滚动到绝对位置。改为使用 scro
在我的 Adapter 中,我调用 LayoutManager.ChildAt(position) 来获取 itemview,但是我得到的 View 不是匹配的 itemview,当我调用 notif
我正在从 ListView 迁移到 RecyclerView,但是在 SQLite 中输入一些数据后,我的列表没有使用 notifyDataSetChanged() 更新;所以我总是要调用setAda
我正在用 Google Now Cards 的风格创建一组 5 张卡片。我首先关注的是总体布局。 我正在使用 CardView 和 RecyclerView ,我想要实现的是这样的: 这是我的 Car
在我的应用程序中,我有一个 RecyclerView,其中包含一个简单的项目 View ,每行包含一个 TextView 和一个 Spinner。 用户从操作栏中单击“保存”后,我需要遍历所有项目并获
我正在尝试检查 RecyclerView 中是否可以看到某些特定项目;但我无法实现。请帮助我确定我的项目是否在 RecyclerView 中完全可见。 mrecylerView.addOnScroll
我有一个提要片段,它的主要元素是帖子的 RecyclerView。 我正在使用 Lisa Wray 的 Groupie 库管理回收站 https://github.com/lisawray/group
我有这两个类似的行为回收器 View 适配器,它们之间的唯一区别是 onclick 方法和传递给它们的对象。所以,我正在考虑将类 B 设计为从回收器 View 适配器继承,这样我就可以更改构造函数来执
这很奇怪。我对这个问题感到沮丧。我将数据保存在 ArrayList 中。当我将数据放在 RecyclerView 上时。数据未显示在列表中。这是我的代码 listOrder.forEach { ord
编辑我通过使用 CoordinatorLayout 和 AppBarLayout 作为 header 和 TabLayout 的包装解决了这个问题。本来应该很明显,但是哦,好吧。 原始问题:我有一个设
我有一个回收 View 。我想从其适配器类更新回收器 View 。我尝试了 notiftDataSetChanged( ) 但它只适用于主类。下面是 recyclerview 适配器类的代码。 pac
我正在使用具有不同 viewholders 的 recyclerview(具有垂直 LinearLayout),其中一个有另一个 RecyclerView(带有水平 LL)。在第二个 recycler
我想创建一个与 Google Play Store 或 Netflix App 类似的布局,其中在单个 RecyclerView 中基本上有多个水平 RecyclerView。如果这不是他们做事的方式
我是一名优秀的程序员,十分优秀!