2

在我的项目中使用Koin作为依赖注入模式,每当我加载片段/活动时,我都需要创建新实例,现在使用以下模式,任何解决方案都可以节省大量时间。

private val homeViewModel: HomeViewModel by viewModel()
4

3 回答 3

0

问题是为什么你每次都想要新的实例?的整个概念ViewModel是保留相同的实例和数据。viewModel {}每次注入时都会创建新实例,除非它没有共享。

不知道为什么它不适合你,但我认为你可以使用factory{} 而不是viewModel{}.

factory{
    // this is because you need new instance everytime.
    HomeViewModel()
}
于 2019-07-03T16:22:52.547 回答
0

您将要放弃使用by viewmodel并直接实例化该类。您可以通过getKoin().get().

private val viewModel = HomeViewModel(getKoin().get())
于 2020-10-20T06:30:58.007 回答
0

将 ViewModel 定义为 BaseFragment 类中的抽象,并在扩展 BaseFragment 时设置值。

abstract class BaseFragment<Binding : ViewDataBinding, ViewModel : BaseViewModel> : Fragment(){
            protected var bindingObject: Binding? = null
            protected abstract val mViewModel: ViewModel

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
            bindingObject = DataBindingUtil.inflate(inflater, getLayoutResId(), container, false)
            return bindingObject?.root
    }

    override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        super.onViewCreated(view, savedInstanceState)
        performDataBinding()
    }

    @LayoutRes
    abstract fun getLayoutResId(): Int

    private fun performDataBinding() {
        bindingObject?.setLifecycleOwner(this)
        bindingObject?.setVariable(BR.viewModel, mViewModel)
        bindingObject?.executePendingBindings()
    }

}

在你的片段中

    class FragmentNew : BaseFragment<FragmentNewBinding, FragmentNewVM>() {
       // Here is the your viewmodel imlementation. Thus when you create fragment it's by default override method
       override val mViewModel: FragmentNewVM by viewModel() 

       override fun getLayoutResId(): Int = [fragment layout id like "R.layout.fragment_new"]
   }
于 2019-06-17T06:38:19.483 回答