GWT-애플리케이션
GWT를 사용하여 실제 "HelloWorld"애플리케이션을 작성하기 전에 GWT 애플리케이션의 실제 부분이 무엇인지 살펴 보겠습니다.
GWT 애플리케이션은 다음 4 개의 중요한 부분으로 구성되며, 그 중 마지막 부분은 선택 사항이지만 처음 세 부분은 필수입니다.
- 모듈 설명자
- 공공 자원
- 클라이언트 측 코드
- 서버 측 코드
일반적인 gwt 응용 프로그램의 여러 부분에 대한 샘플 위치 HelloWord 다음과 같습니다.
이름 | 위치 |
---|---|
프로젝트 루트 | HelloWorld / |
모듈 설명자 | src / com / tutorialspoint / HelloWorld.gwt.xml |
공공 자원 | src / com / tutorialspoint / war / |
클라이언트 측 코드 | src / com / tutorialspoint / client / |
서버 측 코드 | src / com / tutorialspoint / server / |
모듈 설명자
모듈 설명자는 GWT 응용 프로그램을 구성하는 데 사용되는 XML 형식의 구성 파일입니다.
모듈 설명자 파일 확장자는 * .gwt.xml입니다. 여기서 *는 애플리케이션의 이름이며이 파일은 프로젝트의 루트에 있어야합니다.
다음은 HelloWorld 애플리케이션에 대한 기본 모듈 설명자 HelloWorld.gwt.xml입니다.
<?xml version = "1.0" encoding = "utf-8"?>
<module rename-to = 'helloworld'>
<!-- inherit the core web toolkit stuff. -->
<inherits name = 'com.google.gwt.user.user'/>
<!-- inherit the default gwt style sheet. -->
<inherits name = 'com.google.gwt.user.theme.clean.Clean'/>
<!-- specify the app entry point class. -->
<entry-point class = 'com.tutorialspoint.client.HelloWorld'/>
<!-- specify the paths for translatable code -->
<source path = '...'/>
<source path = '...'/>
<!-- specify the paths for static files like html, css etc. -->
<public path = '...'/>
<public path = '...'/>
<!-- specify the paths for external javascript files -->
<script src = "js-url" />
<script src = "js-url" />
<!-- specify the paths for external style sheet files -->
<stylesheet src = "css-url" />
<stylesheet src = "css-url" />
</module>
다음은 모듈 디스크립터에서 사용되는 여러 부분에 대한 간략한 세부 정보입니다.
Sr. 아니. | 노드 및 설명 |
---|---|
1 | <module rename-to = "helloworld"> 이것은 응용 프로그램의 이름을 제공합니다. |
2 | <inherits name = "logical-module-name" /> 이것은 Java 응용 프로그램에서 가져 오기가 수행하는 것처럼 응용 프로그램에 다른 gwt 모듈을 추가합니다. 이러한 방식으로 여러 모듈을 상속 할 수 있습니다. |
삼 | <entry-point class = "classname" /> GWT 애플리케이션로드를 시작할 클래스 이름을 지정합니다. 임의의 수의 진입 점 클래스를 추가 할 수 있으며 모듈 파일에 나타나는 순서대로 순차적으로 호출됩니다. 따라서 첫 번째 진입 점의 onModuleLoad ()가 완료되면 다음 진입 점이 즉시 호출됩니다. |
4 | <source path = "path" /> 이것은 GWT 컴파일러가 소스 컴파일을 검색 할 소스 폴더의 이름을 지정합니다. |
5 | <public path = "path" /> 공개 경로는 CSS 또는 이미지와 같이 GWT 모듈에서 참조하는 정적 리소스가 저장되는 프로젝트의 위치입니다. 기본 공용 경로는 모듈 XML 파일이 저장되는 아래의 공용 하위 디렉토리입니다. |
6 | <script src="js-url" /> src에 지정된 위치에있는 외부 JavaScript 파일을 자동으로 삽입합니다. |
7 | <stylesheet src="css-url" /> src에 지정된 위치에있는 외부 CSS 파일을 자동으로 삽입합니다. |
공공 자원
호스트 HTML 페이지, CSS 또는 이미지와 같이 GWT 모듈에서 참조하는 모든 파일입니다.
이러한 리소스의 위치는 모듈 구성 파일의 <public path = "path"/> 요소를 사용하여 구성 할 수 있습니다. 기본적으로 모듈 XML 파일이 저장되는 위치 아래의 공용 하위 디렉토리입니다.
애플리케이션을 JavaScript로 컴파일하면 공용 경로에서 찾을 수있는 모든 파일이 모듈의 출력 디렉토리에 복사됩니다.
가장 중요한 공용 리소스는 실제 GWT 애플리케이션을 호출하는 데 사용되는 호스트 페이지입니다. 애플리케이션의 일반적인 HTML 호스트 페이지에는 보이는 HTML 본문 콘텐츠가 전혀 포함되지 않을 수 있지만 항상 다음과 같이 <script ... /> 태그를 통해 GWT 애플리케이션을 포함해야합니다.
<html>
<head>
<title>Hello World</title>
<link rel = "stylesheet" href = "HelloWorld.css"/>
<script language = "javascript" src = "helloworld/helloworld.nocache.js">
</script>
</head>
<body>
<h1>Hello World</h1>
<p>Welcome to first GWT application</p>
</body>
</html>
다음은 호스트 페이지에 포함 된 샘플 스타일 시트입니다.
body {
text-align: center;
font-family: verdana, sans-serif;
}
h1 {
font-size: 2em;
font-weight: bold;
color: #777777;
margin: 40px 0px 70px;
text-align: center;
}
클라이언트 측 코드
이것은 애플리케이션의 비즈니스 로직을 구현하여 작성된 실제 Java 코드이며 GWT 컴파일러가 JavaScript로 변환되어 결국 브라우저 내에서 실행됩니다. 이러한 리소스의 위치는 모듈 구성 파일의 <source path = "path"/> 요소를 사용하여 구성 할 수 있습니다.
예를 들면 Entry Point 코드는 클라이언트 측 코드로 사용되며 해당 위치는 <source path = "path"/>를 사용하여 지정됩니다.
모듈 entry-point 할당 할 수있는 모든 클래스입니다. EntryPoint매개 변수없이 구성 할 수 있습니다. 모듈이로드되면 모든 진입 점 클래스가 인스턴스화되고EntryPoint.onModuleLoad()메서드가 호출됩니다. 샘플 HelloWorld 진입 점 클래스는 다음과 같습니다.
public class HelloWorld implements EntryPoint {
public void onModuleLoad() {
Window.alert("Hello, World!");
}
}
서버 측 코드
이것은 응용 프로그램의 서버 측 부분이며 매우 선택 사항입니다. 애플리케이션에서 백엔드 처리를 수행하지 않는 경우이 부분이 필요하지 않지만 백엔드에서 일부 처리가 필요하고 클라이언트 측 애플리케이션이 서버와 상호 작용하는 경우 이러한 구성 요소를 개발해야합니다.
다음 장에서는 위에서 언급 한 모든 개념을 사용하여 Eclipse IDE를 사용하여 HelloWorld 응용 프로그램을 만듭니다.