如何在 Android 自定义数据绑定中传递带参数的函数
How to pass a function with arguments in Android custom data binding
我有一个选项卡布局。当用户单击选项卡时,我想在视图模型中调用“onTabChanged”函数。到目前为止我试过这个:
@BindingAdapter("onTabChanged")
fun setOnTabChanged(tabLayout: TabLayout, onTabChanged: (TabLayout.Tab) -> Unit) {
tabLayout.addOnTabSelectedListener(object: TabLayout.OnTabSelectedListener {
override fun onTabSelected(tab: TabLayout.Tab?) {
tab?.let {
onTabChanged(it)
}
}
override fun onTabUnselected(tab: TabLayout.Tab?) {}
override fun onTabReselected(tab: TabLayout.Tab?) {}
})
}
在layout.xml中:
<data>
<variable
name="viewModel"
type="com.janfranco.ui.menu.MenuViewModel" />
</data>
...
app:onTabChanged="@{viewModel::onTabChanged}"
在视图模型中:
fun onTabChanged(tab: TabLayout.Tab) { }
在布局中,我收到以下错误:Listener class 'kotlin.jvm.functions.Function1<? super com.google.android.material.tabs.TabLayout.Tab,kotlin.Unit>' with method 'invoke' did not match signature of any method 'app:onTabChanged'
我该如何解决这个问题?
在你的 viewModel
而不是这个 :
fun onTabChanged(tab: TabLayout.Tab) { }
你应该有这个:
val onTabChanged = { tab: TabLayout.Tab -> }
我有一个选项卡布局。当用户单击选项卡时,我想在视图模型中调用“onTabChanged”函数。到目前为止我试过这个:
@BindingAdapter("onTabChanged")
fun setOnTabChanged(tabLayout: TabLayout, onTabChanged: (TabLayout.Tab) -> Unit) {
tabLayout.addOnTabSelectedListener(object: TabLayout.OnTabSelectedListener {
override fun onTabSelected(tab: TabLayout.Tab?) {
tab?.let {
onTabChanged(it)
}
}
override fun onTabUnselected(tab: TabLayout.Tab?) {}
override fun onTabReselected(tab: TabLayout.Tab?) {}
})
}
在layout.xml中:
<data>
<variable
name="viewModel"
type="com.janfranco.ui.menu.MenuViewModel" />
</data>
...
app:onTabChanged="@{viewModel::onTabChanged}"
在视图模型中:
fun onTabChanged(tab: TabLayout.Tab) { }
在布局中,我收到以下错误:Listener class 'kotlin.jvm.functions.Function1<? super com.google.android.material.tabs.TabLayout.Tab,kotlin.Unit>' with method 'invoke' did not match signature of any method 'app:onTabChanged'
我该如何解决这个问题?
在你的 viewModel
而不是这个 :
fun onTabChanged(tab: TabLayout.Tab) { }
你应该有这个:
val onTabChanged = { tab: TabLayout.Tab -> }