我们正在评估在out GWT项目中使用GIN,并通过构造函数参数进行典型的注入,取得了良好的结果。我们遇到的困难是现场注入。这些字段总是以null结尾。有没有人有一个很好的例子来说明如何用GIN正确地实现文件级注入?
更新:
下面是一些与我们的代码类似的示例代码:
public class MVP implements EntryPoint {
public static final HandlerManager EVENT_BUS = new HandlerManager(null);
private final MVPInjector _injector = GWT.create(MVPInjector.class);
public void onModuleLoad() {
// set up layout for module
RootLayoutPanel.get().add(mainPanel);
// initialize presenters
ListPresenter listPresenter = _injector.listPresenter();
DetailPresenter detailPresenter = _injector.detailPresenter();
listPresenter.go(listContainer);
detailPresenter.go(detailContainer);
// simulate data coming in from RPC call
EVENT_BUS.fireEvent(new DataReadyEvent(getData()));
}
}
public class ListPresenter {
private final HandlerManager _eventBus;
private final Map<String, Fruit> _myRecords = new HashMap<String, Fruit>();
private final Display _view;
@Inject
public ListPresenter(Display argView, HandlerManager argEventBus) {
_eventBus = argEventBus;
_view = argView;
}
public void go(HasWidgets argContainer) {
argContainer.clear();
argContainer.add(_view.asWidget());
}
public interface Display {
public Widget asWidget();
public void clear();
public SingleSelectionModel<ViewProxy> getSelectionModel();
public void setData(List<ViewProxy> argData);
}
}
public class DetailPresenter {
private final HandlerManager _eventBus;
private final Display _view;
private Fruit _myRecord;
@Inject
private ImagePresenterFactory _imagePresenterFactory;
@Inject
private TestPresenter _testPresenter;
@Inject
public DetailPresenter(Display argView, HandlerManager argEventBus) {
_view = argView;
_eventBus = argEventBus;
}
public void go(HasWidgets argContainer) {
argContainer.clear();
argContainer.add(_view.asWidget());
if (_testPresenter != null) {
_testPresenter.go();
}
}
public interface Display {
public Widget asWidget();
public HasText getDescriptionControl();
public HasClickHandlers getImageControl();
public HasText getNameControl();
public HasClickHandlers getSaveControl();
public void setEnabledControls(boolean argEnabled);
}
}
public class TestPresenter {
@Inject
HandlerManager _eventBus;
public TestPresenter() {}
public void go() {
if (_eventBus != null) {
_eventBus.toString();
}
else {
// event bus was not injected
}
}
}
@GinModules(MVPModule.class)
public interface MVPInjector extends Ginjector {
DetailPresenter detailPresenter();
ListPresenter listPresenter();
}
public class MVPModule extends AbstractGinModule {
@Provides
@Singleton
public HandlerManager getEventBus() {
return MVP.EVENT_BUS;
}
@Provides
public TestPresenter getTestPresenter() {
return new TestPresenter();
}
@Override
protected void configure() {
bind(ListPresenter.Display.class).to(ListView.class);
bind(DetailPresenter.Display.class).to(DetailView.class);
bind(ImagePresenter.Display.class).to(ImagePopup.class);
install(new GinFactoryModuleBuilder().build(ImagePresenterFactory.class));
}
public interface ImagePresenterFactory {
public ImagePresenter createImagePresenter(ImageResource argImage);
}
}在上面的代码中,我删除了大部分不涉及GIN的代码。成功注入DetailPresenter所需的TestPresenter,但TestPresenter所需的HandlerManager始终为空。正如您所看到的,注入的HandlerManager并未在构造函数中使用。
发布于 2012-02-27 10:31:52
更新,查看示例代码:
@Provides
public TestPresenter getTestPresenter() {
return new TestPresenter();
}因为它是您自己创建的,所以它假定您已经处理过任何注入。删除此方法,它将调用默认构造函数(如果需要,可以在那里注入),然后访问任何其他注入站点。
您可能会遇到的另一个问题是:有几个HandlerManager隐含,请确保您对HandlerManager的所有引用都使用相同的包。
原始答案:
当构造函数运行时,它们将是空的,但这是有意义的-当注入器还没有机会分配所有字段时,它们怎么可能是任何其他值。考虑一下这将如何运行(在这里表示为可疑的合法java,因为字段可能不是公共的):
InstanceToInject instance = new InstanceToInject(...);
instance.field = provideFieldValue();当字段有资格被赋值时,你的构造函数已经运行了。
如果在运行另一个方法时该字段为空,请确保该方法不是由构造函数运行的,而是在注入完成其工作之后运行的。其他可能为null的情况是带@Inject注释的setter。
假设不是这些情况(最简单的检查方法是设置断点,并确保注入器不在调用堆栈中),请确保该字段确实有@Inject,并且它没有绑定到空实例。
https://stackoverflow.com/questions/9458683
复制相似问题