web-dev-qa-db-ja.com

アーキテクチャナビゲーションコンポーネント:onCreateViewは毎回呼び出されます

フラグメントインスタンスが作成され、押すと再読み込みされるたび。

この問題を克服する方法は?

Navコントローラーに適切なバックスタックがないことは生産性の大きな問題です。不足している機能または意図的に行われた回避策であることを願っています... IMOこれは必須であり、後でではなく早く導入する必要があります(ただし: https://issuetracker.google.com/issues/109856764 言う当面の間、トランザクションタイプ(非表示/表示など)のカスタマイズは許可されません。) :(

Nav-フレームワークは素晴らしいですが、毎回フラグメントのビューを作成します

誰かが解決策を持っていますか?

私のコードはナビゲーションを使用してナビゲートすることです

object NavigationHelper : Navigational {


override fun moveDownWithPop(view: View,id: Int,popStackId: Int) {
    Navigation.findNavController(view).navigate(id,
            null,
            NavOptions.Builder()
                    .setPopUpTo(popStackId,
                            true).build()
    )
}

override fun moveDownWithDataPop(view: View,id: Int,popStackId: Int,bundle : Bundle) {
    Navigation.findNavController(view).navigate(id,
            bundle,
            NavOptions.Builder()
                    .setPopUpTo(popStackId,
                            true).build()
    )
}

override fun moveUp(view: View) {
    Navigation.findNavController(view).navigateUp()
}

override fun moveDown(view: View,id: Int) {
    Navigation.findNavController(view).navigate(id)
}

override fun moveDown(view: View,id: Int,args : Bundle) {
    Navigation.findNavController(view).navigate(id,args)
}

fun navigateGraph(graphId : Int,context : Context){
    var finalHost: NavHostFragment?  = NavHostFragment.create(graphId)
    (context as MainActivity).supportFragmentManager.beginTransaction()
            .replace(com.admision.R.id.content,finalHost!!)
            .setPrimaryNavigationFragment(finalHost) // this is the equivalent to app:defaultNavHost="true"
            .commit()
}
}

いくつかのブログを見つけました なぜアーキテクチャナビゲーションコンポーネントを使用しないのですか

8
Bhavesh Hirpara

私はこれが好きでした、しかしそれでも私はグーグルからの解決を待っています。

ここで私たちはしましたが、それでもより良いアプローチを待っています

if (manageEventViewModel == null) {
    manageEventViewModel = ViewModelProviders.of(activity!!).get(ManageEventViewModel::class.Java)
    manageEventViewModel!!.setBinder(binding!!,context!!,listingType)
    loadAdvertisement(binding!!.advertise.imgAdvertisement,binding!!.advertise.tvAdvertisement,binding!!.advertise.llAdvertisement)
}

フルコード

class ManageEventsFragment : BaseFragment() {

private var binding: FragmentFindEventsBinding? = null
private var manageEventViewModel: ManageEventViewModel? = null
override fun onCreateView(inflater: LayoutInflater,container: ViewGroup?,savedInstanceState: Bundle?): View? {
    if (binding == null)
        binding = DataBindingUtil.inflate(inflater,R.layout.fragment_find_events,container,false)


    var listingType: String? = null
    if (arguments != null) {
        listingType = arguments!!.getString(Constant.LISTINGTYPE)
        /*if (listingType != null && listingType.equals(Constant.SEARCHLIST)) {
            val data = arguments!!.getString(Constant.SEARCHEVENTMODEL)
            val managetEventDataModel = com.admision.manageevents.utils.Utils.getManageEventDataModel(data)
            manageEventViewModel!!.setSearchDataModel(managetEventDataModel!!)
        }*/
    }

    val sharedViewModel = ViewModelProviders.of(activity!!).get(SharedViewModel::class.Java)
    sharedViewModel!!.dataToShare.observe(this,Observer<ManageEventsDataModel> { managetEventDataModel ->
        listingType = Constant.SEARCHLIST
        manageEventViewModel!!.setSearchDataModel(managetEventDataModel!!)
    })

    if (manageEventViewModel == null) {
        manageEventViewModel = ViewModelProviders.of(activity!!).get(ManageEventViewModel::class.Java)
        manageEventViewModel!!.setBinder(binding!!,context!!,listingType)
        loadAdvertisement(binding!!.advertise.imgAdvertisement,binding!!.advertise.tvAdvertisement,binding!!.advertise.llAdvertisement)
    }
    return binding!!.root
}
}
1
Bhavesh Hirpara

bhaveshが行ったように、私の場合、リストがあり、onCreateViewではこの行だけで十分でした。

if (adapter.isEmpty()) {
            viewModel.getShopCats()
}

そしてアダプタはこれを持っていなければなりませんでした:

fun isEmpty(): Boolean {
        return modelList.isNullOrEmpty()
}
0