Android Fragment Ergebnis Listener





Unter Android kann das Übertragen von Daten zwischen Fragmenten auf verschiedene Arten erfolgen: Übertragen über die übergeordnete Aktivität mithilfe des ViewModel oder sogar der Fragment-API. Die Fragment-Ziel-API hat kürzlich den Status "Veraltet" erhalten. Google empfiehlt, stattdessen die Fragment-Ergebnis-API zu verwenden .



Was ist die Fragment-Ergebnis-API? Dies ist ein neues Tool von Google, mit dem Sie Daten mithilfe eines Schlüssels zwischen Fragmenten übertragen können. Hierzu wird der FragmentManager verwendet, der wiederum die FragmentResultOwner-Schnittstelle implementiert. Der FragmentResultOwner fungiert als zentrales Repository für die Daten, die wir zwischen Fragmenten übertragen.



Wie es funktioniert?



Bild

Wie oben erwähnt, implementiert unser FragmentManager die FragmentResultOwner-Schnittstelle, die er speichert ConcurrentHashMap<String, Bundle>. Diese HashMap speichert unsere Bundles nach String-Schlüssel. Sobald eines der Fragmente signiert ist (oder bereits signiert ist), erhält es das Ergebnis für denselben Schlüssel.



Was ist wichtig zu wissen :



  • - setResultFragmentListener() , setFragmentResult(),
  • “Key + Result (Bundle)“ 1
  • STARTED
  • DESTROYED ResultListener


?





:



FragmentManager.setFragmentResult(key: String, bundle: Bundle)


, Bundle. Bundle .



Kotlin



button.setOnClickListener {
    val result = "result"
    //     Kotlin    fragment-ktx
    setFragmentResult("requestKey", bundleOf("bundleKey" to result))
}


Java



button.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Bundle result = new Bundle();
        result.putString("bundleKey", "result");
        getParentFragmentManager().setFragmentResult("requestKey", result);
    }
});




FragmentManager FragmentResultListener . FragmentManager.setFragmentResult()



Kotlin



override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
     //     Kotlin  
    setFragmentResultListener("requestKey") { key, bundle ->
        //     ,  Bundle-
        val result = bundle.getString("bundleKey")
    }
}


Java



@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    getParentFragmentManager().setFragmentResultListener("key", this, new FragmentResultListener() {
        @Override
        public void onFragmentResult(@NonNull String key, @NonNull Bundle bundle) {
            String result = bundle.getString("bundleKey");
        }
    });
}


2 : key: String bundle: Bundle.

— , . — Bundle, .



Parent Fragment Manger



Bild


FragmentManager- :



  • FragmentManager ( Activity), FragmentManager, Activity
  • , childFragmentManager ( )


, FragmentResultListener FragmentManager-.





/ FragmentResultListener, FragmentScenario API, .





, FragmentManager? , FragmentResultListener :



@Test
fun testFragmentResult() {
    val scenario = launchFragmentInContainer<ResultFragment>()
    lateinit var actualResult: String?
    scenario.onFragment { fragment ->
        fragment.parentFragmentManagager.setResultListener("requestKey") { key, bundle ->
            actualResult = bundle.getString("bundleKey")
        }
    }
    onView(withId(R.id.result_button)).perform(click())
    assertThat(actualResult).isEqualTo("result")
}

class ResultFragment : Fragment(R.layout.fragment_result) {
    override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        view.findViewById(R.id.result_button).setOnClickListener {
            val result = "result"
            setResult("requestKey", bundleOf("bundleKey" to result))
        }
    }
}




, FragmentManager. FragmentResultListener .



@Test
fun testFragmentResultListener() {
    val scenario = launchFragmentInContainer<ResultListenerFragment>()
    scenario.onFragment { fragment ->
        val expectedResult = "result"
        fragment.parentFragmentManagager.setResult("requestKey", bundleOf("bundleKey" to expectedResult))
        assertThat(fragment.result).isEqualTo(expectedResult)
    }
}

class ResultListenerFragment : Fragment() {
    var result : String? = null
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setResultListener("requestKey") { key, bundle ->
            result = bundle.getString("bundleKey")
        }
    }
}




FragmentResultListener ,  Google. , , , . , , , , .



Um den FragmentResultListener verwenden zu können, müssen wir die Version der Fragmente 1.3.0-alpha04 oder neuer in den Abhängigkeiten verbinden :



  • Java-Version: androidx.fragment: fragment: 1.3.0-alpha04
  • Kotlin-Version: androidx.fragment: fragment-ktx: 1.3.0-alpha04
  • Tests: androidx.fragment: Fragment-Test: 1.3.0-alpha04



All Articles