【轉】解決Fragment already active方法

http://blog.csdn.net/u011730649/article/details/43227721java

 

            今天在項目中使用Fragment的時候出現這樣的錯誤:android

01-28 10:53:34.794: E/AndroidRuntime(8703): FATAL EXCEPTION: main
01-28 10:53:34.794: E/AndroidRuntime(8703): Java.lang.IllegalStateException: Fragment already active
01-28 10:53:34.794: E/AndroidRuntime(8703): at Android.app.Fragment.setArguments(Fragment.java:691)
01-28 10:53:34.794: E/AndroidRuntime(8703): at com.hb56.DriverReservation.android.activity.MainActivity.setCurTab(MainActivity.java:239)
01-28 10:53:34.794: E/AndroidRuntime(8703): at com.hb56.DriverReservation.android.fragment.PlanReservationFragment$1.onItemClick(PlanReservationFragment.java:130)
01-28 10:53:34.794: E/AndroidRuntime(8703): at android.widget.AdapterView.performItemClick(AdapterView.java:298)
01-28 10:53:34.794: E/AndroidRuntime(8703): at android.widget.AbsListView.performItemClick(AbsListView.java:1177)
01-28 10:53:34.794: E/AndroidRuntime(8703): at android.widget.AbsListView$PerformClick.run(AbsListView.java:2894)
01-28 10:53:34.794: E/AndroidRuntime(8703): at android.widget.AbsListView$1.run(AbsListView.java:3657)
01-28 10:53:34.794: E/AndroidRuntime(8703): at android.os.Handler.handleCallback(Handler.java:800)
01-28 10:53:34.794: E/AndroidRuntime(8703): at android.os.Handler.dispatchMessage(Handler.java:100)
01-28 10:53:34.794: E/AndroidRuntime(8703): at android.os.Looper.loop(Looper.java:194)
01-28 10:53:34.794: E/AndroidRuntime(8703): at android.app.ActivityThread.main(ActivityThread.java:5400)
01-28 10:53:34.794: E/AndroidRuntime(8703): at java.lang.reflect.Method.invokeNative(Native Method)
01-28 10:53:34.794: E/AndroidRuntime(8703): at java.lang.reflect.Method.invoke(Method.java:525)
01-28 10:53:34.794: E/AndroidRuntime(8703): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
01-28 10:53:34.794: E/AndroidRuntime(8703): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
01-28 10:53:34.794: E/AndroidRuntime(8703): at dalvik.system.NativeStart.main(Native Method)app

              瀏覽了不少論壇裏解決的方法,大體的分析以下:ide

       首先Fragment的傳參方式是這樣的:oop

         設置參數:spa

  1. ft.hide(getActivity().getSupportFragmentManager().findFragmentByTag(""));  
  2.                 SearchProjectFragment sf = new SearchProjectFragment();  
  3.                 Bundle bundle = new Bundle();  
  4.                 bundle.putString("key", Projsid);  
  5.                 sf.setArguments(bundle);  
  6.                 ft.add(R.id.fragmentRoot, sf, SEARCHPROJECT);  
  7.                 ft.addToBackStack(SEARCHPROJECT);  
  8.                 ft.commit(); 

 

   在Fragemnt取參數:.net

getArguments().getString("key");orm

發現Fragment被隱藏後,不能在使用setArguments()傳遞,不然就會報java.lang.IllegalStateException java.lang.IllegalStateException: Fragment already active異常主要是使用setArguments()傳遞參數致使的。 在 Fragment 沒有被添加到 FragmentManager。blog

java.lang.IllegalStateException: Fragment already active異常主要是使用setArguments()傳遞參數致使的。
在 Fragment 沒有被添加到 FragmentManager 以前,咱們能夠經過 Fragment.setArguments() 來設置參數,並在 Fragment 中,使用 getArguments() 來取得參數。在 Fragment 被添加到 FragmentManager 後,一旦被使用,咱們再次調用 setArguments() 將會致使 java.lang.IllegalStateException: Fragment already active 異常。
解決方法:能夠使用setter和getter Fragment的屬性方法進行數據的存儲和獲取。get

相關文章
相關標籤/搜索