Provider vs. Get_it
Asked Answered
D

5

55

Searching for Dependency Injection solutions for Flutter, I found two awesome libraries: provider and get_it.

As far as I can see, provider has more boilerplate, but it fits really nicely with Flutter, allowing Consumer to rebuild parts of the Widget tree, once an injected value change.

get_it on the other hand is more straightforward, easier to use, and not dependant on Flutter, so can be used with any Dart code.

Are there any more differences and limitations between them? I know this is kinda opinionated, but Flutter is so new that it's good to register publicly benefits, side-effects and gotchas.

Dowie answered 23/7, 2019 at 17:45 Comment(0)
F
48

The main difference between both is that provider is not strictly dependency injection.

By using widgets, provider is also able to:

  • providers are compatible with the Flutter devtool
  • know when a variable cannot be accessed (scoped to a tree)
  • know when to create and dispose of an object
  • synchronize model -> model and model -> UI
  • override some values for only a specific widget tree
  • voluntarily prevent circular dependency

All of these are, while optional, good for the health of your app in the long run.

It ensures that you're always up to date, makes it harder to have "spaghetti code", and makes your different elements more composable.

Fleecy answered 23/7, 2019 at 18:1 Comment(6)
Interesting... How is #1 different than #4?Dowie
Preventing circular dependency could be achieved without the model being scoped to a tree. For example, we could have a completely new kind of tree, made only for providers. Similarly, for #1 this also includes trying to obtain a value inside initState and deactivate, which may throw depending on what you do.Judaic
I meant #4, "override some values for only a specific widget tree", but I understand now with that example. Thanks!Dowie
@Rémi-Rousselet So as the developer of Provider, can you give some insight on when using Get It over provider would be preferred?Alage
get_it makes more easier for c# devs to come to flutterLevi
This is too one-sided. get_it is simpler and can be used without a context. It also doesn't clutter your widget tree with Providers for services. So I think it's best to use both, but for different things.Undeviating
E
7

I am explaining just one limitation which I practically found, there may be others too.

After searching many tutorials and topics on Get_it that why people use Get_it() even we have dependency injection in the provider, I was unable to understand the difference in terms of DI. Then I stuck in a Scenario and find the answer to your question that "what are the limitations".

Are there any more differences and limitations between them?.

Scenario:

I had Nested widgets, Widget A has Widget B and Widget B has Widget C, I was using the provider and was accessing values in each widget whenever value changed. It was great, Then I make a new widget D which was a separate widget, it was not inside the widget A hierarchy. But when I try to access the same value in Widget D it was not changing. Because widget D is not in the tree of Widget A. Now here comes the limitation of dependency injection of the provider.

Conclusion

You will use Get_it to access values out of the tree widget. But you can't access the updated value using provider

Updated Answer

In the above scenario, you need to wrap the app with Provider to access all dependencies.

Eldrida answered 2/9, 2020 at 11:23 Comment(1)
Yes, provider works with a widget tree, but most of the times you can inject objects with Provider at the root of your tree so all of your app can read those dependencies.Dowie
P
1

Get It is not a dependency injection solution but a service locator.

It's useful if you want to rapidly switch between two or more implementations of a class. For example to mockup a service, and change between the "real" service or the fake one (for debugging purpose).

Indeed it can't retrieve/supply reference to an existing object (exception is for singleton, but you can do the same by yourself without much more effort) and can supply only new objects.

Perugia answered 21/6, 2020 at 14:42 Comment(0)
C
1

from streaming through various tutorials what I learned is that the get it package can be called a global variable that can be accessed from any widget to any widget whether nested or not nested VS provider which can only be accessed between the nested widget. The example is better explained by M.ArslanKhan

Cohla answered 14/8, 2021 at 17:8 Comment(0)
V
0

In my experience the limitation using Provider is the need for Context. GetIt doesn't have that need. It can really become a headbanger. That's why Provider 2.0 AKA Riverpod was invented.

Venturesome answered 8/12, 2023 at 13:52 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.