Dilemma: when to use Fragments vs Activities:

后端 未结 14 699
失恋的感觉
失恋的感觉 2020-11-22 11:58

I know that Activities are designed to represent a single screen of my application, while Fragments are designed to be reusable UI layouts with log

相关标签:
14条回答
  • 2020-11-22 12:11

    Experts will tell you: "When I see the UI, I will know whether to use an Activity or a Fragment". In the beginning this will not have any sense, but in time, you will actually be able to tell if you need Fragment or not.

    There is a good practice I found very helpful for me. It occurred to me while I was trying to explain something to my daughter.

    Namely, imagine a box which represents a screen. Can you load another screen in this box? If you use a new box, will you have to copy multiple items from the 1st box? If the answer is Yes, then you should use Fragments, because the root Activity can hold all duplicated elements to save you time in creating them, and you can simply replace parts of the box.

    But don't forget that you always need a box container (Activity) or your parts will be dispersed. So one box with parts inside.

    Take care not to misuse the box. Android UX experts advise (you can find them on YouTube) when we should explicitly load another Activity, instead to use a Fragment (like when we deal with the Navigation Drawer which has categories). Once you feel comfortable with Fragments, you can watch all their videos. Even more they are mandatory material.

    Can you right now look at your UI and figure out if you need an Activity or a Fragment? Did you get a new perspective? I think you did.

    0 讨论(0)
  • 2020-11-22 12:11

    My philosophy is this:

    Create an activity only if it's absolutely absolutely required. With the back stack made available for committing bunch of fragment transactions, I try to create as few activities in my app as possible. Also, communicating between various fragments is much easier than sending data back and forth between activities.

    Activity transitions are expensive, right? At least I believe so - since the old activity has to be destroyed/paused/stopped, pushed onto the stack, and then the new activity has to be created/started/resumed.

    It's just my philosophy since fragments were introduced.

    0 讨论(0)
  • 2020-11-22 12:12

    Why I prefer Fragment over Activity in ALL CASES.

    • Activity is expensive. In Fragment, views and property states are separated - whenever a fragment is in backstack, its views will be destroyed. So you can stack much more Fragments than Activity.

    • Backstack manipulation. With FragmentManager, it's easy to clear all the Fragments, insert more than on Fragments and etcs. But for Activity, it will be a nightmare to manipulate those stuff.

    • A much predictable lifecycle. As long as the host Activity is not recycled. the Fragments in the backstack will not be recycled. So it's possible to use FragmentManager::getFragments() to find specific Fragment (not encouraged).

    0 讨论(0)
  • 2020-11-22 12:13

    I use Fragments for better user experience. For example if you have a Button and you want to run let's say a webservice when you click it, I attach a Fragment to the parent Activity.

    if (id == R.id.forecast) {
    
        ForecastFragment forecastFragment = new ForecastFragment();
        FragmentManager fm = getSupportFragmentManager();
        FragmentTransaction ft = fm.beginTransaction();
        ft.replace(R.id.main_content, forecastFragment);
        ft.addToBackStack("backstack");
        forecastFragment.setArguments(b);
        ft.commit();
    }
    

    In that way the user won't have to move in another activity.

    And secondly I prefer Fragments because you can handle them easily during rotation.

    0 讨论(0)
  • 2020-11-22 12:15

    Well, according to Google's lectures (maybe here, I don't remember) , you should consider using Fragments whenever it's possible, as it makes your code easier to maintain and control.

    However, I think that on some cases it can get too complex, as the activity that hosts the fragments need to navigate/communicate between them.

    I think you should decide by yourself what's best for you. It's usually not that hard to convert an activity to a fragment and vice versa.

    I've created a post about this dillema here, if you wish to read some further.

    0 讨论(0)
  • 2020-11-22 12:20

    You are free to use one of those.
    Basically, you have to evaluate which is the best one to your app. Think about how you will manage the business flow and how to store/manage data preferences.

    Think about, how Fragments store garbage data. When you implement the fragment, you have a activity root to fill with fragment(s). So, if your trying to implement a lot of activities with too much fragments, you have to consider performance on your app, coz you're manipulating (coarsely speaks) two context lifecycle, remember the complexity.

    Remember: should I use fragments? Why shouldn't I?

    regards.

    0 讨论(0)
提交回复
热议问题