0

Gxt でデザイナーの作業から Html コードを統合する際に問題が発生したため、非常に単純なテストを実行し、Gwt HtmlPanel を使用して開始することにしましたが、含まれている JavaScript がレンダリングされない理由を説明できません。

public class TestHTML implements EntryPoint {

    public void onModuleLoad() {

        String contenu = "<html>"
         +"<head>"
        +" <script type='text/javascript'>"
        +"function functionOne() { alert('You clicked the top text'); }"
        +"function functionTwo() { alert('You clicked the bottom text'); }"
        +"</script>"
        +"</head>"
        +"<body>"
         +"<p><a href='#' onClick='functionOne();'>Top Text</a></p>"
         +"<p><a href='javascript:functionTwo();'>Bottom Text</a></p>"
         +"</body>"
        +"</html>";
          HTMLPanel htmlPanel = new HTMLPanel(contenu);
          ContentPanel content = new ContentPanel();
          content.add(htmlPanel);
          RootPanel.get().add(content);

    }
} 

ブラウザで JavaScript の機能がわかりません (firebug で調べました) 回答やアドバイスをくれる人はいますか? よろしく

4

1 に答える 1

2

gwt で JSNI を使用する必要があります。

public void onModuleLoad() {
    registerJS();
    String contenu = "<html>"
            +"<body>"
             +"<p><a href='#' onClick='functionOne();'>Top Text</a></p>"
             +"<p><a href='javascript:functionTwo();'>Bottom Text</a></p>"
             +"</body>"
            +"</html>";
              HTMLPanel htmlPanel = new HTMLPanel(contenu);
              RootPanel.get().add(htmlPanel);
}

public native void registerJS()/*-{
    $wnd.functionOne = function(){
        alert('you clicked the top text');
    }

    $wnd.functionTwo = function(){
        alert('you clicked the bottom text');
    }
}-*/;
于 2012-11-09T15:33:17.017 に答える