两个简单Fragment之间的通信(三种方式)
程序员文章站
2022-03-21 13:13:43
两个简单Fragment之间的通信(三种方式)截图如下:点击左侧fragment按钮改变右侧fragment文本在fragment中,getFragmentManager底层还是getactivity.getFragmentManager思路:找第三方,activity第一种根据activity里的布局id获取到相应放置的fragment实例FragmentManager fragmentManager = getFragmentManager();RightFragment id =...
两个简单Fragment之间的通信(三种方式)
截图如下:点击左侧fragment按钮改变右侧fragment文本
在fragment中,getFragmentManager底层还是getactivity.getFragmentManager
思路:找第三方,activity
- 第一种
根据activity里的布局id获取到相应放置的fragment实例
FragmentManager fragmentManager = getFragmentManager();
RightFragment id = (RightFragment) fragmentManager.findFragmentById(R.id.ll_right);
id.changeText("yy");
- 第二种
在replace时为fragment添加一个tag,根据tag获取相应的fragment实例
transaction.replace(R.id.ll_right,new RightFragment(),"sss");
FragmentManager fragmentManager = getFragmentManager();
RightFragment tag = (RightFragment) fragmentManager.findFragmentByTag("sss");
tag.changeText("qqqqq");
3.第三种
可以根据tag获取fragment实例,再根据控件的id获取到fragment的控件进行操作,较为麻烦
FragmentManager fragmentManager = getFragmentManager();
RightFragment tag = (RightFragment) fragmentManager.findFragmentByTag("sss");
View view1 = tag.getView();
TextView tv_result = (TextView) view1.findViewById(R.id.tv_result);
tv_result.setText("dhiwhdiwh");
注意:在fragment中,添加控件的点击事件不能用onclick方法,只能根据控件的id进行findViewById获取控件实例再setOnClickListener
fragment的生命周期
上图就是Fragment完整的生命周期,相比于Activity的生命周期多了如下几个方法
onAttach():当Fragment与Activity发生关联时,该方法被调用
onCreateView():创建Fragment的视图
onActivityCreate():当Activity的onCreate()返回时被调用
onDestoryView():与onCreateView()是对应的,当Fragment的视图被销毁时,该方法被调用
onDetach(): 与onAttach() 方法相对应,当Fragment与Activity的关联被取消时,该方法被调用
本文地址:https://blog.csdn.net/m0_46350041/article/details/107450268
上一篇: Vue看了就会的8个小技巧