在 Fragment 中观察 LiveData 时使用
viewLifecycleOwner
而不是this
。因为 Fragment 和 其中的 View 生命周期不完全一致。LiveData 内部判定生命周期为 DESTROYED 时,才会移除数据观察者。存在一种情况,当 Fragment 之间切换时,被替换的 Fragment 不执行 onDestroy(),当它再次展示时会再次订阅 LiveData,于是乎就多出一个订阅者。
还是购物-结算的场景:购物车和结算页都是两个 Fragment,将商品列表存在共享 ViewMode 的 LiveData 中,购物车及结算页都观察它,结算页除了用它列出购物清单之外,还可以通过更改商品数量来修改 LiveData。当从结算页返回购物车页面时,购物车界面得刷新商品数量。
上述场景,若购物车页面观察 LiveData 时使用this
会发生什么?
// 购物车界面
class TrolleyFragment : Fragment() {
private val myViewModel by lazy {
ViewModelProvider(requireActivity()).get(MyViewModel::class.java)
}
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
return ConstraintLayout {
layout_width = match_parent
layout_height = match_parent
onClick = {
parentFragmentManager.beginTransaction()
.replace("container".toLayoutId(), BalanceFragment())
.addToBackStack("trolley")// 将购物车页面添加到 back stack
.commit()
}
}
}
// 不得不增加这个注释,因为 this 会飘红
@SuppressLint("FragmentLiveDataObserve")
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
// 将 this 作为生命周期拥有者传给 LiveData
myViewModel.selectsListLiveData.observe(this, object : Observer> {
override fun onChanged(t: List?) {
Log.v("ttaylor", "商品数量发生变化")
}
})
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)