GWT嵌入纯HTML页面

  众所周知,gwt页面是java代码所写,不存在html页面直接作用于gwt面板中。不过gwt也倒是提供了一些可用的功能,比如frame,这个是UI中的一个,内部可以设置URL,但是经过我测试后发现,这个frame在生成之后,在嵌套的面板周围会有一个框框,影响美观,具体能不能经过css修改,我没有多测试。日后有时间会试下。

  我这里是要说明的是另一种方法,gwt提供了一个HTML的UI,这个UI有一个方法,即setHTML(String str)。好了,大致已经清楚,就是把一些字符串放到HTML这个UI中,然后就能在页面展示这个HTML了。但是要是把一个html页面的代码全部弄成字符串,有些不切实际。gwt的ClientBundle中提供了方法,可以引用外部资源。详细代码如下:

  

 1 import com.google.gwt.core.shared.GWT;
 2 import com.google.gwt.resources.client.ClientBundle;
 3 import com.google.gwt.resources.client.TextResource;
 4 
 5 public interface HtmlResources extends ClientBundle {
 6 
 7     public static final HtmlResources INSTANCE = GWT.create(HtmlResources.class);
 8     
 9     @Source("page.html")
10     public TextResource getHtml();
11 }

  其中用到了GWT.create()的延迟绑定方法,这里绑定了自身。

  使用方法如下:

HTML html = new HTML();
String str =HtmlResources.INSTANCE.getHtml().getText();
html.setHTML(str);
Panel.add(html);

  使用也是及其简单,就这样把html页面的代码转换成了字符串了。

posted @ 2014-09-09 12:35  BigBang92  阅读(1488)  评论(0编辑  收藏  举报