如何避免fragment预加载重复加载

让你App内的Fragment不再重叠9行代码就搞定
来源:八维教育发布时间: 16:34阅读()
本文来自八维教育
想必很多学习编程的小伙伴们也遇到过同样的问题,app内的Fragment总是重复,但也找不到合适的方法避免。八维教育讲师希望分享以下几行代码能帮助到需要的人。 本文来自八维教育
通过findFragmentByTag() & getFragments()的解决方案 本文来自八维教育
这两种方案在Fragment全解析系列(一):那些年踩过的坑里有比较详细的介绍,可以自行查看,这里不多做介绍,这两种方案也是最常见的解决方案。
缺点: 本文来自八维教育
使用比较麻烦,代码量较多; 本文来自八维教育
在Fragment嵌套的场景下,恢复会有问题,原因在于:页面重启后,在父Fragment没有初始化完成前,getChildFragmentManager()子栈内的子Fragment是空,只有父Fragment初始化完成后,子栈内的子Fragment才能正确获取到。
从源码角度想到的解决方案:自己保存Fragment的Hidden状态 本文来自八维教育
下面这个方案,是我在完善Fragmentation库时想到的方案。 本文来自八维教育
Fragmentation库前几天push了改变重大的0.7版本,应该算是比较成熟了,如果你重度使用Fragment或者想使用单Activity+多Fragment的组件架构的话,强烈推荐看看;对于各种复杂嵌套、同级Fragment的使用场景,你不必担心Fragment的重叠,同时大大简化Fragment的嵌套逻辑。
在上一篇简书分析中,我们知道了发生Fragment重叠的根本原因在于FragmentState没有保存Fragment的显示状态,即mHidden,导致页面重启后,该值为默认的false,即show状态,所以导致了Fragment的重叠。
根据这个原因,我想到我们手动维护一个mSupportHidden不就行了吗? 本文来自八维教育
看下面的基类Fragment代码:
是的你没看错,只要上面的9行代码! FragmentState没帮我们保存Hidden状态,那就我们自己来保存,在页面重启后,我们自己来决定Fragment是否显示! 本文来自八维教育
解决思路转变了,由Activity/父Fragment来管理子Fragment的Hidden状态转变为 由Fragment自己来管理自己的Hidden状态!
优点:不管多深的嵌套Fragment、同级Fragment等场景,全都可以正常工作,不会发生嵌套! 本文来自八维教育
缺点:暂时没有发现。 本文来自八维教育
补充: 本文来自八维教育
有些小伙伴反应还是会重叠,其实是因为加载根Fragment时没有经过判断的原因,当在类似onCreate等初始化生命周期里加载根Fragment(即第一个Fragment)时,需要下面的判断:
& 本文来自八维教育
最后 本文来自八维教育
最后的方案用在了我的Fragmentation库中,在新的仿知乎的Demo里,各种复杂场景表现完美。
(文章内容主体转载于编程之家,如涉及作品内容、版权和其它问题,请在30日内与本网站负责人联系,我们将在第一时间删除内容!)
文章标签:
RECOMMENDATION
相关文章推荐
Relevant article recommended
最新发布文章
RELEVANT ARTICLE RECOMMENDED
EDUCATION NEWS博客分类:
在项目中需要进行Fragment的切换,一直都是用replace()方法来替换Fragment:
public void switchContent(Fragment fragment) {
if(mContent != fragment) {
mContent =
mFragmentMan.beginTransaction()
.setCustomAnimations(android.R.anim.fade_in, R.anim.slide_out)
.replace(R.id.content_frame, fragment) // 替换Fragment,实现切换
.commit();
但是,这样会有一个问题:
每次切换的时候,Fragment都会重新实例化,重新加载一边数据,这样非常消耗性能和用户的数据流量。
就想,如何让多个Fragment彼此切换时不重新实例化?
翻看了Android官方Doc,和一些组件的源代码,发现,replace()这个方法只是在上一个Fragment不再需要时采用的简便方法。
正确的切换方式是add(),切换时hide(),add()另一个Fragment;再次切换时,只需hide()当前,show()另一个。
这样就能做到多个Fragment切换不重新实例化:
public void switchContent(Fragment from, Fragment to) {
if (mContent != to) {
mContent =
FragmentTransaction transaction = mFragmentMan.beginTransaction().setCustomAnimations(
android.R.anim.fade_in, R.anim.slide_out);
if (!to.isAdded()) {
// 先判断是否被add过
transaction.hide(from).add(R.id.content_frame, to).commit(); // 隐藏当前的fragment,add下一个到Activity中
transaction.hide(from).show(to).commit(); // 隐藏当前的fragment,显示下一个
浏览 16503
相关知识库:
gundumw100
浏览: 4207331 次
来自: 上海
本地lua脚本终于执行成功了,虽然不是通过redis
大神://处理返回的接收状态
这个好像没有监听到
拦截部分地址,怎么写的for(int i=0;i&lis ...
Android控件之带清空按钮(功能)的AutoComplet ...
希望有表例子更好。。。,不过也看明白了。
(window.slotbydup=window.slotbydup || []).push({
id: '4773203',
container: s,
size: '200,200',
display: 'inlay-fix'其他回答(2)
一个很笨的办法,就是将覆盖住的fragment的所用view或者根view设置成Gone或者INVISIBLE
收获园豆:100
/** * 压入栈管理 * * @param fragment * @param tag */private void push(Fragment fragment, String tag) { FragmentTransaction ft = getSupportFragmentManager().beginTransaction(); ft.replace(R.id.main_container, fragment, tag); ft.addToBackStack(tag); ft.commitAllowingStateLoss(); getSupportFragmentManager().executePendingTransactions();}protected &T& T findFragmentByTag(String tag) { return (T) getSupportFragmentManager().findFragmentByTag(tag);}/** * 主页 */private void goMainIndexFragment() { if (currentItem == Navigations.MAIN_INDEX) { } MainIndexFragment activitiesFragment = findFragmentByTag(MainIndexFragment.className); push(activitiesFragment == null ? MainIndexFragment.newInstance() : activitiesFragment, MainIndexFragment.className);}
&&&您需要以后才能回答,未注册用户请先。转载自http://m.blog.csdn.net/article/details?id=
在网上有看到提升fragment加载速度的方法,故转载过来,侵权即删
1 public void handler(int index){
fragmentTransaction = fragmentManager.beginTransaction();
switch (index) {
//如果tabFragment1为空,说明还没创建Tab1
if(tabFragment1==null){
tabFragment1 = new TabFragment1();
//如果isAdded == true 表示 tab1 已加入布局中
if(!tabFragment1.isAdded()){
fragmentTransaction.add(R.id.content,tabFragment1);
//如果tab2不为空,把tab2隐藏就是、
if(tabFragment2!=null){
fragmentTransaction.hide(tabFragment2);
//Log.v("rush_yu", "hh");
//显示tab1
fragmentTransaction.show(tabFragment1);
//如果tabFragment2为空,说明还没创建Tab2
if(tabFragment2==null){
tabFragment2 = new TabFragment2();
//如果isAdded == true 表示 tab2 已加入布局中
if(!tabFragment2.isAdded()){
fragmentTransaction.add(R.id.content,tabFragment2);
//如果tab2不为空,把tab1隐藏就是、
if(tabFragment1!=null){
fragmentTransaction.hide(tabFragment1);
//显示tab2
fragmentTransaction.show(tabFragment2);
//Log.v("rush_yu", "hh1");
阅读(...) 评论() &防止每次切换radio button重复加载fragment - 简书
防止每次切换radio button重复加载fragment
发现Index中使用radiobutton+Fragment并不是想象中的用Fragment的replace实现切换。这样的确会造成切换的时候重新初始化加载网络数据啥的。特别是Fragment里面的数据很复杂的时候。而是这样:
Fragmentfragment = (Fragment)mFragmentPagerAdapter.instantiateItem(mContainer, R.id.rb_microstore);mFragmentPagerAdapter.setPrimaryItem(mContainer,0, fragment);mFragmentPagerAdapter.finishUpdate(mContainer);privateFragmentPagerAdaptermFragmentPagerAdapter=newFragmentPagerAdapter(getSupportFragmentManager()) {@Overridepublic voidsetPrimaryItem(ViewGroup container,intposition, Object object) {currentPosition=super.setPrimaryItem(container, position, object);}@OverridepublicFragment getItem(intposition) {switch(position) {caseR.id.rb_discover:return newDiscoverFrag();caseR.id.rb_circle:return newCircleFrag();caseR.id.rb_myinfo:return newPersonalCenterFrag();caseR.id.rb_microstore:default:return newMicroStoreFrag();}}@Overridepublic intgetCount() {return4;}};实现checkchangeListener @Overridepublic voidonCheckedChanged(CompoundButton buttonView,booleanisChecked) {if(isChecked) {Fragment fragment = (Fragment)mFragmentPagerAdapter.instantiateItem(mContainer, buttonView.getId());mFragmentPagerAdapter.setPrimaryItem(mContainer,0, fragment);mFragmentPagerAdapter.finishUpdate(mContainer);}}这样不会多次创建各种Fragment。也会很流畅。这样需要在Fragment中重写@Overridepublic voidsetMenuVisibility(booleanmenuVisible) {super.setMenuVisibility(menuVisible);if(this.getView() !=null)this.getView().setVisibility(menuVisible ? View.VISIBLE: View.GONE);}否则会导致重影。哈哈。今天就遇到了
当做记点笔记(?-?)?

我要回帖

更多关于 android 加载fragment 的文章

 

随机推荐