Difference between Dagger and ButterKnife Android
Asked Answered
P

5

69

Can anyone point out the difference between Dagger and Butterknife? I know that Butterknife is a view injection library and Dagger is a dependency injection library. But the documentation online seems a bit overhead for me. According to Butterknife documentation, you can do non-activity injections as well, which is what Dagger does? Or did I misunderstand something?

Plagiarize answered 29/12, 2013 at 1:13 Comment(0)
N
98

ButterKnife is targeted to inject views only. Non-activity injection just means that you can provide your own view root to inject views from (like with manually inflated views, etc.). Dagger is a bit more complicated. It can inject anything you want as long as you specified Module - class which satisfies those dependencies (alternatively you can use constructor injection).

As a bottom line - I would say ButterKnife helps you to avoid all that boilerplate code for creating views (aka (TextView)findViewById(R.id.some_text_view);. Nothing more. Under the hood it still does all that boring code. So it is not really an injection..

Also it worth mentioning that Jake Wharton is one of the developers for both those cool libs :)

Here is some useful links:

Dagger sample project on GitHub

Dagger presentation on Devoxx (Jake Wharton)

Dagger hangout with Dagger devs

Don't have much of useful ButterKnife links. It really simple and straight forward though, so hopefully you don't need any

Numerous answered 29/12, 2013 at 1:49 Comment(8)
so do you mean that we can use dagger to inject textviews,editviews etc?Plagiarize
I believe you can inject views in Dagger using qualifiers (see QUALIFIERS section in Dagger documentation) where you pass id as a qualifier, but it would look really weird. I thinks Dagger creators will be really surprised if they find out someone is using Dagger for views injection:) But technically, I don't see any reasons why it shouldn't work..Numerous
To be honest, there isn't much documentation online on how to use dagger,butterknife. I am looking for some tutorials but can't find any. And the official docs seem to much overhead for me to grasp everything. I shall accept your answer anyways, but if you can post some useful links, it would be helpful. Cheers!Plagiarize
If you use Dagger to try and inject views you're going to have a very bad time :) Try to think of Butter Knife as a means of binding views rather than injection. I only called it injection because all the RoboGuice converts were complaining about lack of "view injection" with Dagger. It's not really injection at all. Like the answer mentions, it's just a way to reduce boilerplate. Under the hood it's just calling findViewById like you would!Casein
Straight from the horses mouth... So to speak. Spreading the good word! :)Suzerainty
As per me, Dagger and Butterknife both complement each other. We can use both together in our project.Foreshorten
Pavel Dudka and @JakeWharton, you have a high score in dagger. Can you please cast your votes to mark other tags like dagger-android and dagger.android as synonyms of tag dagger?Cryoscope
@PavelDudka #68231312 pls look and help meBeisel
E
5

Here is a link to the Buterknife documentation. It's very straightforward. However, what the documentation doesn't say but the design of Butter Knife implies is that you can also use Butter Knife in custom views. Just replace "this" with "context" or "getContext" so you determine the scope.

Link: http://jakewharton.github.io/butterknife/

I combine Butter Knife, parcelable and easyAdapter for list views in my project. Reason is less boilerplate and with parcelable faster and cleaner parceling. So if you have a lot of ListViews, I recommend this approach.

Links:

https://github.com/johncarl81/parceler

https://github.com/ribot/easy-adapter

Evolutionist answered 22/4, 2014 at 8:59 Comment(0)
L
5

@JakeWharton's answers it partially in the comment:

TL;DR: They complement each other. Use Butterknife for injecting views, Dagger for the rest.

If you use Dagger to try and inject views you're going to have a very bad time :) Try to think of Butter Knife as a means of binding views rather than injection. I only called it injection because all the RoboGuice converts were complaining about lack of "view injection" with Dagger. It's not really injection at all. Like the answer mentions, it's just a way to reduce boilerplate. Under the hood it's just calling findViewById like you would!

Libretto answered 19/6, 2015 at 11:27 Comment(1)
No wonder it was renamed to ViewBinder in the latest version then.Legaspi
C
4

The difference is pretty straightforward: A butter knife is like a dagger only infinitely less sharp.
As it is pointed out in the documentation.

Cryoscope answered 25/4, 2015 at 21:38 Comment(3)
I actually read this in the documentation but ended up here for a better explanation.Subhead
But a dagger implies only infinite more boilerplate code for view binding, because you have to cast any View subclass you could get. ButterfKnife determines cast type at compile time. You, can't tell dagger to do so.Vermeil
@LouisCAD Dagger is not designed for view binding (see comment).Cryoscope
L
0

ButterKnife was made to simplify registering click listeners, and to reduce the boilerplate provided by findViewById() calls.

Dagger and Dagger2 are general purpose dependency injection systems.

Ignore the text on Guice and MVVM, and read Dependency Injection and The Android Way. This pretty much answers what Dagger is meant to do and simplify.

https://spring.io/blog/2011/08/26/clean-code-in-android-applications

Legaspi answered 7/4, 2016 at 19:16 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.