Dagger 2 - 将 class 注入声明的接口
Dagger 2 - Injecting class to declared interface
我在我的 ApiService 中依赖于 class(用户)。我的组件 class 中已经有一个 provideUser
。我正在尝试将相同的 provideUser my User class 注入到 2 个字段。问题是一个字段是 class 而第二个是这样的接口:
@Inject
User user;
@Inject
UserFull userFull;
和组件代码:
package com.ltx.dagger2.components;
import com.ltx.dagger2.activities.MainActivity;
import com.ltx.dagger2.modules.BackendServiceModule;
import com.ltx.dagger2.modules.UserModule;
import javax.inject.Singleton;
import dagger.Component;
@Singleton
@Component(modules = {UserModule.class, ... other stuff})
public interface AppComponent {
void inject(MainActivity activity);
}
等式的其他元素:
public class User implements UserFull {
String firstName;
String lastName;
public User(String firstName, String lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
@Override
public String toString() {
return "User{" +
"firstName='" + firstName + '\'' +
", lastName='" + lastName + '\'' +
'}';
}
@Override
public String getFullName() {
return firstName + " " + lastName;
}
}
public interface UserFull {
String getFullName();
}
和模块代码:
package com.ltx.dagger2.modules;import com.ltx.dagger2.models.User; import com.ltx.dagger2.models.UserFull; import javax.inject.Singleton;import dagger.Module; import dagger.Provides;
@Module
public class UserModule {
@Singleton
@Provides
User provideUser() {
return new User("Hakuna","Matata");
}
}
我可以强制 Dagger2 向 UserFull 字段提供相同的用户 class 还是我总是必须添加特定的 UserFull provideUserFull
方法?
最简单的方法是在 @Module
中创建另一个方法,它将 User
作为参数,return 作为 UserFull
:
@Module
public class UserModule {
@Singleton
@Provides
User provideUser() {
return new User("Hakuna","Matata");
}
@Provides
UserFull provideUserFull(User user) {
return user;
}
}
User
参数将通过 provideUser()
方法实现。
Dagger 无法自行猜测它必须提供哪种 UserFull
实现。这就是为什么你必须指定它并添加第二个方法。
我在我的 ApiService 中依赖于 class(用户)。我的组件 class 中已经有一个 provideUser
。我正在尝试将相同的 provideUser my User class 注入到 2 个字段。问题是一个字段是 class 而第二个是这样的接口:
@Inject
User user;
@Inject
UserFull userFull;
和组件代码:
package com.ltx.dagger2.components;
import com.ltx.dagger2.activities.MainActivity;
import com.ltx.dagger2.modules.BackendServiceModule;
import com.ltx.dagger2.modules.UserModule;
import javax.inject.Singleton;
import dagger.Component;
@Singleton
@Component(modules = {UserModule.class, ... other stuff})
public interface AppComponent {
void inject(MainActivity activity);
}
等式的其他元素:
public class User implements UserFull {
String firstName;
String lastName;
public User(String firstName, String lastName) {
this.firstName = firstName;
this.lastName = lastName;
}
@Override
public String toString() {
return "User{" +
"firstName='" + firstName + '\'' +
", lastName='" + lastName + '\'' +
'}';
}
@Override
public String getFullName() {
return firstName + " " + lastName;
}
}
public interface UserFull {
String getFullName();
}
和模块代码:
package com.ltx.dagger2.modules;import com.ltx.dagger2.models.User; import com.ltx.dagger2.models.UserFull; import javax.inject.Singleton;import dagger.Module; import dagger.Provides;
@Module
public class UserModule {
@Singleton
@Provides
User provideUser() {
return new User("Hakuna","Matata");
}
}
我可以强制 Dagger2 向 UserFull 字段提供相同的用户 class 还是我总是必须添加特定的 UserFull provideUserFull
方法?
最简单的方法是在 @Module
中创建另一个方法,它将 User
作为参数,return 作为 UserFull
:
@Module
public class UserModule {
@Singleton
@Provides
User provideUser() {
return new User("Hakuna","Matata");
}
@Provides
UserFull provideUserFull(User user) {
return user;
}
}
User
参数将通过 provideUser()
方法实现。
Dagger 无法自行猜测它必须提供哪种 UserFull
实现。这就是为什么你必须指定它并添加第二个方法。