5

次の方法で、GWT メソッドをネイティブ JavaScript にエクスポートしています。

public class FaceBookGalleryEntryPoint implements EntryPoint {

    @Override
    public void onModuleLoad() {

        FacebookGallery facebookGallery = new FacebookGallery();
        RootPanel.get().add(facebookGallery);

        initLoadGallery(facebookGallery);
    }

    private native void initLoadGallery(FacebookGallery pl) /*-{
        $wnd.loadGallery = function (galleryId) {
            pl.@com.example.fbg.client.FacebookGallery::loadGallery(Ljava/lang/String;)(galleryId);
        };
    }-*/;
}

ホストページで、私はそれを呼び出そうとしています:

<html>
    <head>
        <title>Facebook image gallery</title>
        <script type="text/javascript"
            src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>     
    </head>

    <body>
        <script type="text/javascript" src="/fbg/fbg.nocache.js"></script>
        <h1>Facebook gallery test</h1>
        <script type="text/javascript">
            $(document).ready(function() {
                loadGallery('blargh');              
            });
        </script>
    </body>
</html>

残念ながら、document.ready コールバックが呼び出されたとき、関数はまだ定義されていません。Firebug コンソールから手動で実行すると、関数は問題なく動作します。

その名前で定義された関数が見つかるまで、50 ミリ秒ごとにポーリングを実行できますが、それは恐ろしいアプローチのようです。

モジュールがロードされたとき、つまり関数が利用可能になったときに通知を受け取るにはどうすればよいですか?

4

1 に答える 1

14

ホストページでコールバック関数を定義し、onModuleLoad() メソッドの最後で GWT から呼び出すようにします。

ホストページ機能:

<script type="text/javascript">
  function onGwtReady() {
    loadGallery('blargh');              
  };
</script>

GWT:

public void onModuleLoad() {
  FacebookGallery facebookGallery = new FacebookGallery();
  RootPanel.get().add(facebookGallery);

  initLoadGallery(facebookGallery);

  // Using a deferred command ensures that notifyHostpage() is called after
  // GWT initialisation is finished.
  Scheduler.get().scheduleDeferred(new Command() {
    public void execute() {
      notifyHostpage();
    }
  }
}

private native void notifyHostpage() /*-{
  $wnd.onGwtReady();
}-*/;
于 2010-11-18T00:23:53.837 に答える