LiveData概述及运用

LiveData

一. 概述

由于ViewModel可以保存UI数据但是无法及时通知Activity更新,也不能通过将Activity实例传入ViewModel进行通知,因此有了LiveData。

LiveData是一个可观察的数据存储类,它可以包含任何类型的数据,并在数据发生变化的时候通知给观察者,也就是Activity,让它及时更新。LiveData只会将更新通知传递给处于活跃状态的观察者(STARTED\RESUMED)。

当Lifecycle对象的状态变为DESTROYED的时候,也就是Activity\Fragment生命周期被销毁时,系统会立即退订

二. 导入依赖

一般而言,LivaData不需要特别的导入依赖,但是其中需要的observe方法的语法拓展,因此需要以下依赖

implementation 'androidx.lifecycle:lifecycle-livedata-ktx:2.2.0'

三. 基本用法

LivaData是一种可用于任何数据的封装容器,LiveData对象通常存储在ViewModel对象中

LiveData为不可变对象,其子类MutableLiveData为可变对象

一般而言,为保证ViewModel的封装性,只暴露不可变的LiveData在外部,使得非ViewModel对象只能观察到数据变化而不能设置数据

1. 设置ViewModel类

在这一部分添加了参数,因此需要参考ViewModel部分进行相应设置

class ActivityViewModel(textReserved: String) : ViewModel() {
    val text: LiveData<String>
        get() = _text
    private val _text = MutableLiveData<String>()
    init {
        _text.value = textReserved
    }
    fun changeText(p: String){
        _text.value = p
    }
}

2. 设置主函数

对ViewModel中的内容更改,应该使用ViewModel中的函数

对UI的更改,可以使用observe方法,进行监听更改

class MainActivity : AppCompatActivity() {
    private lateinit var tvMainShow: TextView
    private lateinit var btnMainChange: Button
    private lateinit var activityViewModel: ActivityViewModel
    private lateinit var sharedPreferences: SharedPreferences
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        tvMainShow = findViewById(R.id.tv_main_show)
        btnMainChange = findViewById(R.id.btn_main_change)
        sharedPreferences = getPreferences(Context.MODE_PRIVATE)
        val text = sharedPreferences.getString("text", "无内容")
        activityViewModel = ViewModelProvider(
            this,
            ActivityViewModelFactory(text!!)
        ).get(ActivityViewModel::class.java)
        btnMainChange.setOnClickListener {
            activityViewModel.changeText("已改变")
        }
        activityViewModel.text.observe(this, Observer { content ->
            tvMainShow.text = content
        })
    }

    override fun onPause() {
        super.onPause()
        sharedPreferences.edit {
            putString("text", activityViewModel.text.toString())
        }
    }
}

四. map和switchMap

· map

将实际包含数据的LiveData转换成真正需要展示的LiveData并转换为相应类型

ViewModel类

class ActivityViewModel : ViewModel() {
    private val userLiveData = MutableLiveData<User>()
    val userName: LiveData<String>
        get() = _userName
    //map转化
    private val _userName: MutableLiveData<String> = Transformations.map(userLiveData){ user ->
            "${user.firstName} ${user.lastName}"
        } as MutableLiveData<String>
    fun changeUserName(name: String){
        _userName.value = name
    }
}

主函数

class MainActivity : AppCompatActivity() {
    private lateinit var tvMainShow: TextView
    private lateinit var btnMainChange: Button
    private lateinit var activityViewModel: ActivityViewModel
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        tvMainShow = findViewById(R.id.tv_main_show)
        btnMainChange = findViewById(R.id.btn_main_change)
        activityViewModel = ViewModelProvider(
            this,
            ViewModelProvider.AndroidViewModelFactory(application)
        ).get(ActivityViewModel::class.java)
        btnMainChange.setOnClickListener {
            val name = (0..1000).random().toString()
            activityViewModel.changeUserName(name)
        }
        activityViewModel.userName.observe(this, {user ->
            tvMainShow.text = user
        })

    }
}
· switchMap

当LiveData实例并不是在ViewModel中创建时,想要将实际包含数据的LiveData转换成真正需要展示的LiveData并转换为相应类型则需要使用switchMap

例如:

在ViewModel外创建了LiveData

object Repository {
    fun getUser(userName: String): LiveData<User>{
        val liveData = MutableLiveData<User>()
        liveData.value = User(userName, userName, 18)
        return liveData//每次返回一个新的LiveData
    }
}

那么此时要获得可观察的LiveData,则ViewModel如下:

class ActivityViewModel : ViewModel() {
    private val userLiveData = MutableLiveData<String>()
    val userName: LiveData<User> = Transformations.switchMap(userLiveData){name ->
        Repository.getUser(name)//只获得一次LiveData,始终观察这一个,并且进行转化
    }
    fun changeUserName(name: String){
        userLiveData.value = name
    }
}

主函数如下:

class MainActivity : AppCompatActivity() {
    private lateinit var tvMainShow: TextView
    private lateinit var btnMainChange: Button
    private lateinit var activityViewModel: ActivityViewModel
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        tvMainShow = findViewById(R.id.tv_main_show)
        btnMainChange = findViewById(R.id.btn_main_change)
        activityViewModel = ViewModelProvider(
            this,
            ViewModelProvider.AndroidViewModelFactory(application)
        ).get(ActivityViewModel::class.java)
        btnMainChange.setOnClickListener {
            val name = (0..1000).random().toString()
            activityViewModel.changeUserName(name)
        }
        activityViewModel.userName.observe(this, {user ->
            tvMainShow.text = user.firstName /
        })

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LiveData 是用于在 Android 应用程序中观察数据的一个组件。LiveData 是一个可观察的数据持有者类,它具有生命周期感知能力,因此它会自动管理它与 Activity 和 Fragment 生命周期的关系,从而可以避免内存泄漏和崩溃。 LiveData 的一个重要特性是它可以通知观察者数据已更改。当 LiveData 的值发生更改时,它会自动通知所有观察者。这意味着您无需手动更新 UI 或执行其他操作以反映数据更改。LiveData 还支持数据转换和过滤,因此您可以将原始数据转换为 UI 可以直接使用的格式。 LiveData 使用观察者模式进行数据监听,您可以使用 `observe()` 方法将观察者添加到 LiveData 实例中,该方法需要传入一个 LifecycleOwner 和一个 Observer 对象。LifecycleOwner 表示 LiveData 与哪个组件的生命周期绑定,通常是 Activity 或 Fragment。Observer 对象定义了当 LiveData 的值更改时要执行的操作。 下面是一个简单的示例,演示如何使用 LiveData 监听数据更改: ``` // 创建一个 LiveData 实例 val myLiveData = MutableLiveData<String>() // 将观察者添加到 LiveData 实例中 myLiveData.observe(this, Observer { newValue -> // 在这里更新 UI 或执行其他操作 textView.text = newValue }) // 更改 LiveData 的值 myLiveData.value = "Hello World" ``` 在上面的示例中,我们创建了一个名为 `myLiveData` 的 LiveData 实例,并将其与当前组件的生命周期绑定。我们还将一个 Observer 对象传递给 `observe()` 方法,以便在 LiveData 的值更改时执行操作。当我们调用 `myLiveData.value = "Hello World"` 时,LiveData 会自动通知所有观察者,以便更新 UI 或执行其他操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值