java - 如何在没有 Maven 的情况下将 GWT 和 Material Design Library 结合起来?

标签 java gwt material-design gwt-material-design

我试图使用 Central Maven Repo 中的 MD 库只需下载 jar 并在 Eclipse 中使用普通的 Java 项目即可。

Central Maven Repo 我使用了 jar gwt-material因为它在编译过程中说我也需要 MD-jQuery-lib,所以我将该 jar 集成为 gwt-material-jQuery ,也是。

所以跟着你会发现

  • gwt.xml:我在其中继承 gwt 项目所需的所有库
  • entryPoint 类 ( Addressbook2 ) 具有 onModuleLoad() -方法
  • UIBinder类,需要在entryPoint类中添加一个实例
  • UIBinder.ui.xml 文件,其中 MatDes-Lib 集成为资源字段

对于这么大的帖子,提前表示歉意。不知道如何包装得更紧凑。

因此,在 Eclipse 中运行和编译它现在可以与 GWT Development Mode with Jetty 一起使用。 ,集成MatDes-jQuery-Lib之后,但是当我在本地主机打开地址http://127.0.0.1:8888/Addressbook.html时我只是得到一个没有内容的白色浏览器窗口,甚至无法打开开发工具。我是否在配置中遗漏了某些内容,或者代码不正确,我必须对其进行调整?

gwt.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE module PUBLIC "-//Google Inc.//DTD Google Web Toolkit 2.8.2//EN"
  "http://gwtproject.org/doctype/2.8.2/gwt-module.dtd">
<module rename-to='addressbook'>
  <inherits name='com.google.gwt.user.User'/>
  <inherits name='com.google.gwt.user.theme.clean.Clean'/>
  <inherits name='gwt.material.design.jquery.JQuery'/>
  <inherits name='gwt.material.design.GwtMaterialDesignBasic'/>

  <!-- Specify the paths for translatable code                    -->
  <source path='client'/>
  <source path='shared'/>
  <entry-point class='addressbook.client.Addressbook2'/>
  <!-- allow Super Dev Mode -->
  <add-linker name="xsiframe"/>
  <set-configuration-property name="CssResource.enableGss" value="true" />
  <extend-property name="locale" values="de, en"/>
  <set-property-fallback name="locale" value="en"/>
</module>

入口点类

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.RootLayoutPanel;

import addressbook.client._2view.MainViewUIB;
public class Addressbook2 implements EntryPoint {

    @Override
    public void onModuleLoad() {
        Window.alert("Hello, World!");
        RootLayoutPanel.get().add(new MainViewUIB());
    }
}

MainViewUIB 类

package addressbook.client._2view;

import com.google.gwt.core.client.GWT;
import com.google.gwt.uibinder.client.UiBinder;
import com.google.gwt.uibinder.client.UiField;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.Widget;

import gwt.material.design.client.resources.MaterialResources;

public class MainViewUIB extends Composite {

    private static final MainViewUIBUiBinder uiBinder = GWT.create(MainViewUIBUiBinder.class);

    interface MainViewUIBUiBinder extends UiBinder<Widget, MainViewUIB> {
    }

    public MainViewUIB() {
        initWidget(uiBinder.createAndBindUi(this));
    }

    @UiField(provided = true)
    MaterialResources res;
}

MainViewUI.ui.xml

<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
    xmlns:m="urn:import:gwt.material.design.client.ui">
    <ui:with type="gwt.material.design.client.resources.MaterialResources" field="res"></ui:with>
    <m:MaterialPanel>
        <m:MaterialIcon marginTop="120" iconType="POLYMER" iconSize="LARGE"/>
        <m:MaterialLabel text="Hello MD World" fontSize="2em"/>
        <m:MaterialLabel text="Start building now your gwt-material apps." fontSize="0.8em"/>
    </m:MaterialPanel>
</ui:UiBinder>

这是我通过检查 chrome 页面得到的结果,我只在页面上得到一个元素:

<iframe id="addressbook" tabindex="-1" style="position: absolute; width: 0px; height: 0px; border: none; left: -1000px; top: -1000px;">
<script src="http://127.0.0.1:9876/addressbook/0A7EA82001E95E9BED1D0ABA0EF89DEF.cache.js"></script>
</iframe>

最佳答案

@UiField(provided = true)
MaterialResources res;

provided=true 表示 .ui.xml 不需要创建此资源,因为您将在调用 createAndBind 之前提供它。如果不这样做,可能会导致在尝试创建小部件时发生 NullPointerExceptions,这将导致该路径上没有任何内容可见。但是,您的 .ui.xml 中实际上似乎没有使用 res (除了在 ui:with 中声明,这就像将其声明为变量),因此您可以删除该字段和指向它的 ui:with

关于java - 如何在没有 Maven 的情况下将 GWT 和 Material Design Library 结合起来?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53646446/

相关文章:

html - 设置 MUI 选择宽度?

java - 在8843端口启动Jboss服务器5.x

Java:lambda 表达式连接多个字符串参数

java - ResultSet 和 ResultSetMetaData 之间的交互是单向的吗?

java - 在Itext中获取pdf文件内容

在 UIBinder 中具有子元素配置的 gwt 自定义小部件(如 CustomButton)

css - 删除行之间的底部填充物化

java - 注释处理期间的 GWT RfValidator NPE

java - GWT 与 Eclipse 下的 Maven。开发周期是多少?

javascript - 你如何向 Angular Material 添加搜索栏?