私はタブレイアウトのネストされたフラグメントを持つ単純なアプリケーションに取り組んでいます。親アクティビティはLandingActivityです。 LandingActivityの中で私はLandingFragmentを呼び出しています。 LandingFragmentの中には次のような機能があります。ネストされたフラグメントidが見つかりませんでした
Tasks TAB Fragments flow is TasksMainFragment->TasksFragment->DetailFragment.
Pending TAB Fragments flow is PendingMainFragment->PendingFragment->PendingDetailFragment
次のコードは、TasksMainFragmentからTasksFragmentを呼び出すことを表しています。
TasksFragment fragment=new TasksFragment();
FragmentManager fragmentManager = getActivity().getSupportFragmentManager();
FragmentTransaction fragmentTransaction=fragmentManager.beginTransaction();
fragmentTransaction.add(R.id.id_frame, fragment, "tasks");
fragmentTransaction.addToBackStack("tasks");
fragmentTransaction.commit();
以下のコードは、TasksFragmentの呼び出しDetailFragmentを表しています。基本的にTasksFragmentにはいくつかのタスクを含むrecyclerviewが含まれています。ユーザーがタスクをタップすると、タスクのDetailFragmentが開きます。
Fragment fragment = new DetailFragment();
FragmentManager manager = ((FragmentActivity) mContext).getSupportFragmentManager();
FragmentTransaction fragmentTransaction = manager.beginTransaction();
Bundle bundle = new Bundle();
ItemModel item = list.get(position);
bundle.putSerializable("item", item);
bundle.putBoolean("having", havingStartedService());
fragment.setArguments(bundle);
fragmentTransaction.replace(R.id.id_frame, fragment, "details");
fragmentTransaction.addToBackStack("details");
fragmentTransaction.commit();
ユーザーが保留中のタブに切り替えると、同じ動作または同じ機能が動作します。しかし、問題は、私がこの問題に直面している毎日朝にアプリケーションを開いたり、いくつかの時間の後に開いたり、アプリケーションを開いたりするときです。
私はこの問題に直面している私も画面の向きを変更する他のシナリオ。
私は理解を深めるために以下のlogcatを投稿しています。
12-20 16:33:01.658 21590-21590/com.naushad.kenostaff E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.naushad.kenostaff, PID: 21590
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.naushad.kenostaff/com.naushad.kenostaff.landing.LandingActivity}: java.lang.IllegalArgumentException: No view found for id 0x7f070059 (com.naushad.kenostaff:id/id_frame) for fragment TasksFragment{b980f0d #7 id=0x7f070059 tasks}
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2684)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2751)
at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:4556)
at android.app.ActivityThread.-wrap19(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1502)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6186)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:889)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:779)
Caused by: java.lang.IllegalArgumentException: No view found for id 0x7f070059 (com.naushad.kenostaff:id/id_frame) for fragment TasksFragment{b980f0d #7 id=0x7f070059 tasks}
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1293)
at android.support.v4.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1528)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1595)
at android.support.v4.app.BackStackRecord.executeOps(BackStackRecord.java:758)
at android.support.v4.app.FragmentManagerImpl.executeOps(FragmentManager.java:2363)
at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2149)
at android.support.v4.app.FragmentManagerImpl.optimizeAndExecuteOps(FragmentManager.java:2103)
at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:2013)
at android.support.v4.app.FragmentController.execPendingActions(FragmentController.java:388)
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:607)
at android.support.v7.app.AppCompatActivity.onStart(AppCompatActivity.java:181)
at com.stfalcon.androidmvvmhelper.mvvm.activities.BindingActivity.onStart(BindingActivity.java:50)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1249)
at android.app.Activity.performStart(Activity.java:6701)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2647)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2751)
at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:4556)
at android.app.ActivityThread.-wrap19(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1502)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6186)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:889)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:779)
この問題について私に助けてください。私は過去1週間からこの問題に直面している、私は非常に多くの方法を試みたが、何も役立たない。前もって感謝します。両方のクラッシュを解決.I getChildFragmentManager()代わりにgetActivity.getSupportFragmentManager()を使用することにより
「idが見つかりません」親としてSingle Activityを使用していますか? – ADM
はい親として1つのアクティビティを使用しています – malli