GWT MVP体系结构优势
我正在学习GWT,我在多个地方都读到,使用MVP体系结构最适合开发GWT应用程序 我也读过,使用MVP架构进行测试很容易。有人能解释一下为什么使用MVP架构进行测试很容易吗 此外,我正在使用MVP进行一个项目,我发现将视图连接到数据库非常繁琐。我的意思是,为了连接到数据库,我必须更新我的演示者、服务、服务异步、服务CIMPL、FacadesGWT MVP体系结构优势,gwt,mvp,Gwt,Mvp,我正在学习GWT,我在多个地方都读到,使用MVP体系结构最适合开发GWT应用程序 我也读过,使用MVP架构进行测试很容易。有人能解释一下为什么使用MVP架构进行测试很容易吗 此外,我正在使用MVP进行一个项目,我发现将视图连接到数据库非常繁琐。我的意思是,为了连接到数据库,我必须更新我的演示者、服务、服务异步、服务CIMPL、Facades 有人能给我介绍一下MVP for GWT的精髓吗?我希望能举几个例子。演示者(包含逻辑)和视图(围绕UI控件的愚蠢包装)之间的分离允许您: 为演示者编写单
有人能给我介绍一下MVP for GWT的精髓吗?我希望能举几个例子。演示者(包含逻辑)和视图(围绕UI控件的愚蠢包装)之间的分离允许您:
- 为演示者编写单元测试,无需相应的环境(桌面、浏览器、GWT小部件)即可运行
- 重用前端逻辑,而无需绑定到一组特定的小部件/UI框架
public class ButtonClickPresenter {
public interface View {
HasText currentValue();
HasClickHandlers incrementButton();
}
private final View myView;
private int currentValue = 0;
public ButtonClickPresenter(View myView) {
this.myView = myView;
this.myView.currentValue().setText("0");
this.bind(); // for the sake of demonstration
}
public void bind() {
this.myView.incrementButton.addClickHandler(
@Override
new ClickHandler() {
void onClick(ClickEvent event) {
currentValue ++;
myView.currentValue().setText(
Integer.toString(currentValue));
}
});
}
}
“真实”视图返回UI小部件(在本例中通过UiBinder创建):
鉴于单元测试创建了一个虚拟实现(或使用等),因此不需要任何UI组件:
public class ButtonClickPresenterTest {
ButtonClickPresenter presenter;
ClickHandler currentHandler;
String currentText;
@Before
public void setUp() {
presenter = new ButtonClickPresenter(
// dummy view - just stores label text in a String and
// keeps track of the Presenter's click handler
new ButtonClickPresenter.View() {
@Override
public HasText currentValue() {
return new HasText() {
@Override public String getText() { return currentText; }
@Override public void setText(String text) { currentText = text; }
};
}
@Override
public HasClickHandlers incrementButton() {
return new HasClickHandlers() {
@Override
public HandlerRegistration addClickHandler(ClickHandler handler) {
currentHandler = handler;
}
};
}
});
}
@Test
public void testIncrement() {
// initial value
assertEquals("0", currentText);
// clicking the button should increment the number
currentHandler.onClick(null);
assertEquals("1", currentText);
}
}
至于你的下一段:你的视图根本不应该连接到数据库!演示者应该通过Service/ServiceAsync(或诸如或之类的抽象)请求数据,然后调用视图上的方法来填充UI
顺便说一句,如果您正在寻找GWT MVP代码示例,那么最后两个链接(以及)是一个很好的开始——它们提供了将所有这些内容结合在一起的框架
说了这么多,我同意——GWT+MVP+Java的结合可能是一项艰苦的工作,而且非常冗长(我很高兴我现在不需要太多地使用它)。然而,另一种选择就更不吸引人了:一个不稳定、无法维护的意大利面球……您可能想看看博客上关于gwt平台应用程序的示例-> 干杯 标记
public class ButtonClickPresenterTest {
ButtonClickPresenter presenter;
ClickHandler currentHandler;
String currentText;
@Before
public void setUp() {
presenter = new ButtonClickPresenter(
// dummy view - just stores label text in a String and
// keeps track of the Presenter's click handler
new ButtonClickPresenter.View() {
@Override
public HasText currentValue() {
return new HasText() {
@Override public String getText() { return currentText; }
@Override public void setText(String text) { currentText = text; }
};
}
@Override
public HasClickHandlers incrementButton() {
return new HasClickHandlers() {
@Override
public HandlerRegistration addClickHandler(ClickHandler handler) {
currentHandler = handler;
}
};
}
});
}
@Test
public void testIncrement() {
// initial value
assertEquals("0", currentText);
// clicking the button should increment the number
currentHandler.onClick(null);
assertEquals("1", currentText);
}
}