MVVM(Model-View-ViewModel)是一种基于数据绑定的设计模式,它与传统的 MVC 和 MVP 模式相比,更加适合处理复杂的 UI 逻辑和数据展示。在 Android 开发中,MVVM 通常使用 Data Binding 和 ViewModel 实现。

下面是一个简单的示例,介绍如何在 Android 中使用 MVVM。
首先,我们需要在项目中添加 Data Binding 和 ViewModel 相关依赖:
android {
    ...
    dataBinding {
        enabled = true
    }
}
dependencies {
    ...
    implementation 'androidx.lifecycle:lifecycle-viewmodel:2.4.0'
    implementation 'androidx.lifecycle:lifecycle-livedata:2.4.0'
}
 
接着,我们创建一个 Model 类,用于存储数据:
data class User(val name: String, val age: Int)
 
然后,我们创建一个 ViewModel 类,用于处理数据逻辑:
class UserViewModel : ViewModel() {
    private val _user = MutableLiveData<User>()
    val user: LiveData<User>
        get() = _user
    init {
        _user.value = User("张三", 18)
    }
    fun changeUserName(newName: String) {
        val oldUser = _user.value ?: return
        _user.value = oldUser.copy(name = newName)
    }
}
 
在上面的代码中,我们使用了 LiveData 来管理数据,并且提供了一个 changeUserName() 方法,用于修改用户的名字。
接下来,我们创建一个布局文件,用于展示数据:
<layout xmlns:android="http://schemas.android.com/apk/res/android">
    <data>
        <variable
            name="viewModel"
            type="com.example.sample.UserViewModel" />
    </data>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">
        <TextView
            android:text="@{viewModel.user.name}"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
        <Button
            android:text="修改名字"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:onClick="@{() -> viewModel.changeUserName(`李四`)}"/>
    </LinearLayout>
</layout>
 
在上面的代码中,我们使用了 Data Binding 来绑定 ViewModel,并且使用了双向数据绑定来展示用户的名字。同时,我们还提供了一个按钮,用于修改用户的名字。
最后,我们在 Activity 中使用 ViewModel 和 Data Binding 来展示数据:
class MainActivity : AppCompatActivity() {
    private lateinit var binding: ActivityMainBinding
    private val viewModel by viewModels<UserViewModel>()
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        binding = DataBindingUtil.setContentView(this, R.layout.activity_main)
        binding.lifecycleOwner = this
        binding.viewModel = viewModel
    }
}
 
在上面的代码中,我们使用了 viewModels() 方法来创建 ViewModel,并且使用 Data Binding 来绑定 ViewModel 和布局文件。同时,我们还指定了 Activity 为布局文件的生命周期所有者,以便 LiveData 正确地进行数据更新。
综上所述,以上就是一个简单的 Android MVVM 示例代码。在实际开发中,MVVM 可以更好地分离业务逻辑和 UI 展示,使代码更加清晰和易于维护。


















