Child pages
  • Your First Project - Hello World

Versions Compared


  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Migrated to Confluence 5.3

For your first project, we will do the classic "Hello world" example. This tutorial is more for learning how the development tools works.

First, we will create a new Wonder Application. In Eclipse, open the File menu, select New and select Wonder Application.


If the Wonder project types don't appear in the File->New menu, you are probably in a Java perspective instead of WOLips.
Go to the Window->Open Perspective->Other... menu and select WOLips.

The project wizard will ask for the project name. Enter HelloWorld. Click Finish.


Don't put spaces in the project name, Eclipse has a hard time with projects that have spaces in the file system path.

The project have been created, you will see it in the WO Explorer tab. Expand it (click on the triangle next to the project name) and you will see the following folders:

  • Sources: this folder holds all of your Java source code. When you create a new project, that folder have 4 files:,, and
  • JRE System Library: don't touch this.
  • Components: this folder holds all of your Project Wonder components.
  • Libraries: if you have JARs, for example JDBC drivers, that you need for your project, put them in there.
  • Resources: that folder is for Project Wonder-specific files. A Properties file is added by default.
  • WebServerResources: that folder is for "static" content that you use in your components, be it images, CSS or JavaScript files.
  • woproject: this folder holds 6 files that the Ant builder use to include or exclude files and folders in the build product. 99% of the time, you don't need to customize those files.
  • build.xml: This is the XML file to build the project with Ant. Note that this is to build a "product", when you run the project in Eclipse, it use the incremental builder instead of Ant.

So let's run the project. Expand the Sources folder, expand the package, right-click on and select Run As -> WOApplication. This action will start the project and it will create a run configuration for Eclipse.

After a couple of seconds, the project will be started and a page will open in your favorite browser. You just ran your first Project Wonder application, congratulations!

Now, let's make the "Hello World" to be dynamic. If the HelloWorld application is still running, terminate it by clicking on the square red button in the Console tab.

In the project, open the Sources folder, open the package and open is the Java part of a Project Wonder component. If you check the content of the Related tab, you will see that is related to other files like Main.wo and Main.api, it's a good way to find out if a Java class is part of a component.

In the editor tab, you will need to put one variable + one setter + one getter. Complete code:

Code Block
private String myTextForDisplay = "Hello World from the Java world";

public String myTextForDisplay() {
  return myTextForDisplay;

public void setMyTextForDisplay(String myTextForDisplay) {
  this.myTextForDisplay = myTextForDisplay;

Save the file.

So now we have a variable to display the content of a string. The next step is to open the HTML part of the component to actually display the string. In the Related view, double-click on the Main.wo file. This action will open the component in the Component Editor.

Remove the Hello World text from the HTML and replace it with:

Code Block
<wo:str value = "$myTextForDisplay" />

And save your modifications. You are now ready to run the application again. The first time you ran the application, it created a run configuration inside Eclipse, so to run the application again, click on the green circle with a white arrow in the toolbar, and select HelloWorld.

The application is now displaying the string for the Java variable! You can terminate the application.

Final step: making the string truly variable by having a small text field to update the string. To do so, go back into the Main component editor view and just after the <wo:str call, add:

Code Block
<br />
<wo:textfield value = "$myTextForDisplay" />
<wo:submit action = "~updateString" />

Now we have a simple form to update the string. The only thing we need to do is to implement the updateString method. Open the file and add the following code:

Code Block
public WOActionResults updateString() {
		return null;

Run the project again, and update the string in the text field. It's now 100% dynamic! Since we added a setter for the variable a couple of steps before, you don't need to set the string in the updateString method, that's the power of bindings.

You can move on to the next tutorial.