No Android, a transferência de dados entre fragmentos pode ser feita de diferentes maneiras: transferência por meio da Activity pai usando o ViewModel ou mesmo a API Fragments. A API Fragment Target recebeu recentemente o status Deprecated e o Google recomenda usar a API Fragment result .
O que é Fragment result API? Esta é uma nova ferramenta do Google que permite transferir dados entre fragmentos usando uma chave. Para isso, é utilizado o FragmentManager, que por sua vez implementa a interface FragmentResultOwner. O FragmentResultOwner atua como um repositório central para os dados que passamos entre os fragmentos.
Como funciona?
Conforme mencionado acima, nosso FragmentManager implementa a interface FragmentResultOwner, que ele armazena ConcurrentHashMap<String, Bundle>. Este HashMap armazena nossos Pacotes por chave de string. Assim que um dos fragmentos é assinado (ou já assinado), ele recebe o resultado para a mesma chave.
O que é importante saber :
- -
setResultFragmentListener(),setFragmentResult(), - “Key + Result (Bundle)“ 1
-
STARTED -
DESTROYEDResultListener
?
:
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

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. , , , . , , , , .
Para poder usar o FragmentResultListener, precisamos incluir a versão dos fragmentos 1.3.0-alpha04 ou mais recente nas dependências :
- Versão Java: androidx.fragment: fragmento: 1.3.0-alpha04
- Versão do Kotlin: androidx.fragment: fragment-ktx: 1.3.0-alpha04
- Testes: androidx.fragment: fragment-testing: 1.3.0-alpha04