android fragment 嵌套,Fragment嵌套Fragment时遇到的那些坑

由于项目要改成MVP模式,自然会用到了Fragment,有时候可能会需要一个Fragment里面嵌套多个Fragment,并且add完成后需要立即刷新子Fragment的View,那么这个时候就会抛出异常,先看一段代码:

MainActivity.java

@Override

protected void onCreate(Bundle savedInstanceState) {

setContentView(R.layout.activity_main);

//省略逻辑代码。。。

mMessageFragment = MessageFragment.newInstance();

getSupportFragmentManager()

.beginTransaction().add(R.id.layout_activity_main_fragment_contianer, mMessageFragment)

.commitAllowingStateLoss();

}

MessageFragment.java

@Override

public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

View rootView = inflater.inflate(R.layout.fragment_message, null);

ButterKnife.bind(this, rootView);

return rootView;

}

@Override

public void onActivityCreated(Bundle savedInstanceState) {

super.onActivityCreated(savedInstanceState);

initFragment();

updateFragment();

}

private void updateFragment(){

for(int i=0;i

mMessageFragments[i].update();

}

}

private void initFragment() {

replyFragment = ConversationListFragment.newInstance(false);

replyFragment);

privateFragment = ConversationListFragment.newInstance(true);

privateFragment);

mMessageFragments = new Fragment[]{ replyFragment, privateFragment};

getChildFragmentManager()

.beginTransaction()

.add(R.id.fragment_container, replyFragment)

.add(R.id.fragment_container, privateFragment)

.hide(privateFragment)

.show(replyFragment)

.commitAllowingStateLoss();

}

ConversationListFragment.java

public static ConversationListFragment newInstance(boolean isprivate) {

ConversationListFragment fragment = new ConversationListFragment();

Bundle args = new Bundle();

args.putBoolean("isprivate", isprivate);

fragment.setArguments(args);

return fragment;

}

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

if (getArguments() != null) {

mIsPrivate = getArguments().getBoolean("isprivate");

}

}

@Nullable

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view = inflater.inflate(R.layout.fragment_message_conversation_list, null);

ButterKnife.bind(this, view);

return view;

}

public void update(){

//当代码运行到这里的时候就会发生错误

//比如:mIsPrivated的值是默认值,并没有获取到外部传过来的值,如果逻辑代码中需要用到View,则还会抛出空指针异常!

if(mIsPrivated){

//省略逻辑。。。

}else{

//省略逻辑。。。

}

}

分析原因

相信只要仔细看过上面的代码的都应该明白错误的原因了,主要原因就是对Fragment生命周期了解的不够透彻,因为在父Fragment的onActivityCreated方法中虽然实例化了子Fragment但是子Fragment的生命周期方法并没有被调用,所以这个时候子Fragment的View还没有被创建,如果直接在父Fragment的onActivityCreated方法中调用子Fragment更新View的方法就会抛出异常!

解决方案

既然知道了是因为子Fragment生命周期方法未执行引起的,那么就应该把更新子Fragmet的调用时机放到父Fragment的onActivCreated方法之外,可以放到父Fragment的onStart方法中即可!

总结

其实主要是对Fragment生命周期方法不熟造成的,再次回忆总结一下Fragment生命周期方法:

58196b8116cf

1354170699_6619.png

Activity与Fragment对比图

58196b8116cf

1354170682_3824.png

生命周期分析:

ragment被创建的时候

onAttach()

onCreate()

onCreateView()

onActivityCreated()

2.fragment对用户可见的时候

onStart()

onResume()

fragment进入“后台模式”的时候

onPause()

onStop()

fragment被销毁的时候

onPause()

onStop()

onDestroyView()

onDestroy()

onDetach()

就像activitie一样,在以下的状态中,可以使用Bundle对象保存一个fragment的对象。

onCreate()

onCreateView()

onActivityCreated()

fragments的大部分状态都和activitie很相似,但fragment有一些新的状态。

onAttached() —— 当fragment被加入到activity时调用(在这个方法中可以获得所在的activity)。

onCreateView() —— 当activity要得到fragment的layout时,调用此方法,fragment在其中创建自己的layout(界面)。

onActivityCreated() —— 当activity的onCreated()方法返回后调用此方法

onDestroyView() —— 当fragment中的视图被移除的时候,调用这个方法。

onDetach() —— 当fragment和activity分离的时候,调用这个方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Android中的Fragment可以嵌套其他Fragment,这种方式被称为Fragment嵌套嵌套Fragment可以让我们更加灵活地组织和管理UI界面,同也可以提高代码的复用性和可维护性。在嵌套Fragment,需要注意一些细节,比如在父Fragment中添加子Fragment,需要使用getChildFragmentManager()方法来获取FragmentManager对象,而不是使用getFragmentManager()方法。此外,还需要注意Fragment的生命周期管理,避免出现重叠或重复创建的情况。 ### 回答2: Android中,Fragment可以理解为一个可替换的Activity组件,用于构造多屏幕应用程序中的视图。而嵌套Fragment,是指在一个Fragment中创建另一个Fragment,以此来实现复杂的界面和交互效果。 在使用嵌套Fragment,需要注意以下几点: 1. 嵌套Fragment的添加方式有两种,一种是在xml中添加,另一种是在java代码中添加。 2. Fragment嵌套需要使用getChildFragmentManager()来获取子FragmentManager,而不是getFragmentManager()。 3. 在嵌套Fragment中,可以使用FragmentTransaction来进行事务的操作,比如添加、移除、替换、隐藏、显示等。 4. 当父Fragment销毁,子Fragment也会被销毁;当子Fragment被添加到另一个父Fragment,原来的父Fragment会先将子Fragment移除,然后为新的父Fragment添加子Fragment。 5. 当嵌套Fragment较多,可能会导致内存消耗较大,因此需要合理管理Fragment的生命周期。 总的来说,嵌套Fragment可以更加灵活地构建复杂的UI和交互效果,但在使用需要注意遵循上述规则,以避免出现一些非预期的问题。 ### 回答3: Android应用开发中,Fragment是非常重要的组件之一。它可以被看作是一个独立的子页面,可以在Activity内嵌入多个Fragment实现页面的灵活组合。而Fragment嵌套Fragment是指在一个Fragment中,再嵌套一个新的Fragment。这种做法可以使得应用页面更加灵活多变,同提高了Fragment的复用性和可维护性。 在进行Fragment嵌套Fragment候,需要注意以下几点: 1. Fragment管理:在Activity中使用FragmentManager来管理Fragment,而在Fragment中使用getChildFragmentManager来管理其中嵌套Fragment。这样可以有效避免Fragment嵌套出现的一些问题。 2. 生命周期:Fragment嵌套要注意各个Fragment的生命周期,特别是当外层Fragment与内层Fragment的生命周期不同,需要在编写代码的候进行适当的调整。为了避免错误的业务逻辑,请确保正确处理onAttach、onCreate、onCreateView、onDestroyView、onDestroy、onDetach等生命周期方法。 3. 布局:嵌套Fragment在布局方式上,可以继承父Fragment的布局方式,也可以采用独立的布局方式。具体使用哪种方式,可以根据实际情况进行选择。 4. 事件传递:当内部Fragment需要向外部Fragment或者Activity发送事件的候,可以采用接口回调的方式。而当外部Fragment向内部Fragment中传递事件,则可以使用子FragmentManager.findFragmentById()或者子FragmentManager.findFragmentByTag()方法来获取子Fragment,并进行相关调用。 总之,Fragment嵌套Fragment的运用,能够使得我们的应用更具灵活性和可扩展性,但在具体应用中要注意生命周期及事件传递等诸多细节问题,以达到最佳实践效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值