Android MVVN 使用入门

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 展示,使代码更加清晰和易于维护。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT徐师兄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值