如何在显示下一个视图之前清除RootPanel

时间:2016-10-21 04:57:07

标签: java html gwt paypal

我正在使用GWT Java,当我从LoginView移动到另一个视图时,我正在尝试删除PayPal Donate按钮(即清除RootPanel),这是HTML表单的一部分。我发现我应该使用:

    RootPanel.get("payPalDonate").clear();
    RootPanel.get().clear();
    RootPanel.get().getElement().setInnerHTML("");

这样可以清除表单,因此它不会出现在下一个视图中;但是,当显示下一个视图时,视图上的按钮,超链接和浏览器后退按钮不起作用。

代码位于:

private void checkWithServerIfSessionIdIsStillLegal(String sessionID) {

    rpc = (DBConnectionAsync) GWT.create(DBConnection.class);
    ServiceDefTarget target = (ServiceDefTarget) rpc;
    String moduleRelativeURL = GWT.getModuleBaseURL() + "MySQLConnection";
    target.setServiceEntryPoint(moduleRelativeURL);

    AsyncCallback<Account> callback = new AuthenticationHandler<Account>();
    rpc.loginFromSessionServer(callback);
}

class AuthenticationHandler<T> implements AsyncCallback<Account> {
    @Override
    public void onFailure(Throwable caught) {
        RootPanel.get().add(new LoginView());
    }

    @Override
    public void onSuccess(Account result) {
        if (result == null) {
            RootPanel.get().add(new LoginView());
        } else {
            //if (result.getLoggedIn()) {
                RootPanel.get().clear();
                //RootPanel.get().add(new SelectPersonView());
                RootPanel.get().add(new LoginView());
            //} else {
                //RootPanel.get().add(new LoginView());
            //}
        }
    }

}

public void onValueChange(ValueChangeEvent<String> event) {

    RootPanel.get("payPalDonate").clear();
    RootPanel.get().clear();
    RootPanel.get().getElement().setInnerHTML("");

    //Get the historyToken value
    String historyToken = event.getValue();

    //Check the historyToken
    if (historyToken.startsWith("!"))
        historyToken = historyToken.substring(1);

    if (historyToken.length() == 0) {   
        //Initial entry
        RootPanel.get().clear();
        RootPanel.get().add(new LoginView());
    } else if (historyToken.equals("login")) {
        RootPanel.get().clear();
        RootPanel.get().add(new LoginView());
    } else if (historyToken.equals("goToVideo")) {
        RootPanel.get().clear();
        Window.Location.replace("https://www.youtube.com/user/GlyndwrBartlett");
    } else if (historyToken.equals("goToMetawerx")) {
        RootPanel.get().clear();
        Window.Location.replace("https://www.metawerx.net/");
    } else if (historyToken.equals("goToPrivacy")) {
        RootPanel.get().clear();
        RootPanel.get().add(new SecurityAndPrivacyView());
    } else if ...

在LoginView中:

    initWidget(verticalPanel);
    RootPanel.get("payPalDonate");

在html中:

       <div style="margin:auto" id="payPalDonate">
            <form action="https://www.paypal.com/cgi-bin/webscr" method="post" target="_top">
                <input type="hidden" name="cmd" value="_s-xclick">
                <input type="image" src="https://www.paypalobjects.com/en_AU/i/btn/btn_donateCC_LG.gif" border="0" name="submit" alt="PayPal – The safer, easier way to pay online!">
                <img alt="" border="0" src="https://www.paypalobjects.com/en_AU/i/scr/pixel.gif" width="1" height="1">
            </form>
        </div>

2 个答案:

答案 0 :(得分:2)

通常在GWT中,RootPanel永远不会被清除。当您启动应用程序时,将容器传递给RootPanel,然后将所有视图添加到该容器中以及从该容器中删除。

就个人而言,我对所有应用都使用Activities and Places模式。此链接提供了如何在主容器中更改视图的示例。

答案 1 :(得分:0)

我正在阅读Andrei提供的链接。与此同时,我发现这些问题正在被解决:

RootPanel.get().getElement().setInnerHTML("");

我试过了:

RootPanel.getBodyElement().removeChild(RootPanel.get("payPalDonate").getElement());

然而,这也解决了同样的问题。最后我找到了https://groups.google.com/forum/#!topic/google-web-toolkit/zVvY39blkY4

所以我用以下内容替换了违规代码:

RootPanel.get("payPalDonate").setVisible(false);

在我将控制传递给另一个视图之前,我将代码放在了LoginView中。不是最优雅的;但是,它一直有效,直到我消化了Andrei提供的信息。