Android 使用扩展方法进行Kotlin数据绑定
我试图在Android的数据绑定中使用Kotlin扩展方法。例如调用onclick处理程序。因此,我制定了以下代码: posttest_list_item.xmlAndroid 使用扩展方法进行Kotlin数据绑定,android,kotlin,kotlin-android-extensions,kotlin-extension,Android,Kotlin,Kotlin Android Extensions,Kotlin Extension,我试图在Android的数据绑定中使用Kotlin扩展方法。例如调用onclick处理程序。因此,我制定了以下代码: posttest_list_item.xml <?xml version="1.0" encoding="utf-8"?> 因此,当我将clicked方法放在viewmodel中时,它的工作方式与它应该的工作方式完全相同。但是,当我将其创建为扩展方法时,在编译时出现以下错误: e:[kapt]发生异常:android.databinding.tool.util.Lo
<?xml version="1.0" encoding="utf-8"?>
因此,当我将clicked方法放在viewmodel中时,它的工作方式与它应该的工作方式完全相同。但是,当我将其创建为扩展方法时,在编译时出现以下错误:
e:[kapt]发生异常:android.databinding.tool.util.LoggedErrorException:发现数据绑定错误。
在类…PostItemViewModel中找不到已单击的方法(android.view.view)
我已经尝试过不同的方法,比如将android:onclick
标记改为PostTestItemViewModelExtensionKt
,而不是viewModel
。不幸的是,所有的事情似乎都不起作用。因此,看起来扩展方法是在数据绑定发生后生成的。有办法解决这个问题吗?还是我还是做错了什么?或者仅仅是绑定扩展方法是不可能的
我正在使用Kotlin版本1.2.71,gradle 3.2.0,将
数据绑定{enabled=true}
和kapt{generateStubs=true}
添加到我的.gradle中,并将插件Kotlin android
,kotlin android扩展
和kotlin kapt
已定义。不幸的是,您不能将扩展方法用作onClick
回调
Kotlin中的扩展方法被创建为Java静态方法,而Android框架需要一个实例方法
请注意,在Android Studio中,您可以将Kotlin类反编译为Java以查看生成的Java代码。Java(即Android框架)无法访问afaik的扩展方法,因此您需要将
单击的方法放入类中itself@zaplJava可以访问扩展方法,但是以PostTestItemViewModelExtensionKt.clicked(postTestItemViewModelInstance)
的形式。扩展方法是Java的静态方法。所以实际上,android:onClick=“@{(视图)->PostTestItemViewModelExtensionKt.clicked(viewModel,view)}”
可以工作吗?看看这个问题:
<data>
<import type="android.view.View"/>
<import type="com.example.test.post.posttest.PostTestItemViewModelExtensionKt" />
<variable
name="viewModel"
type="com.example.test.post.posttest.PostTestItemViewModel" />
</data>
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingLeft="16dp"
android:paddingRight="16dp"
android:clickable="true"
android:onClick="@{(view) -> viewModel.clicked(view)}"
>
[...]
open class PostTestItemViewModel : ViewModel() {
val postTitle = MutableLiveData<String>()
val postBody = MutableLiveData<String>()
/**
* Binds the required properties/entities to this ViewModel
*/
fun bind(post: Post) {
postTitle.value = post.title
postBody.value = post.body
}
}
fun PostTestItemViewModel.clicked(v: View) {
this.postTitle.value = "clicked"
}