WML Tutorial on WML Events

event in ordinary language can be defined as something happened. in programming, event is identical in meaning, but with one major difference. when something happens in a computer system, the system itself has to (1) detect that something has happened and (2) know what to do about it.

wml language also supports events and you can specify an action to be taken whenever an event occurs. this action could be in terms of wmlscript or simply in terms of wml.

wml supports following four event types:

  • onenterbackward: this event occurs when the user hits a card by normal backward navigational means. that is, user presses the back key on a later card and arrives back at this card in the history stack.

  • onenterforward: this event occurs when the user hits a card by normal forward navigational means.

  • onpick: this is more like an attribute but it is being used like an event. this event occurs when an item of a selection list is selected or deselected.

  • ontimer: this event is used to trigger an event after a given time period.

these event names are case sensitive and they must be lowercase.

wml <onevent> element:

the <onevent>...</onevent> tags are used to create event handlers. its usage takes the following form:

<onevent type="event_type">
   a task to be performed.
</onevent>

you can use either go, prev or refresh task inside <onevent>...</onevent> tags against an event.

the <onevent> element supports the following attributes:

attribute value description
type
  • onenterbackward
  • onenterforward
  • onpick
  • ontimer
defines a type of event occured.
class class data sets a class name for the element.
id element id a unique id for the element.

following is the example showing usage of <onevent> element. in this example, whenever you try to go back from second card to first card then onenterbackward occurs which moves you to card number three. copy and paste this program and try to play with it.

<?xml version="1.0"?>
<!doctype wml public "-//wapforum//dtd wml 1.2//en"
"http://www.wapforum.org/dtd/wml12.dtd">

<wml>
<onevent type="onenterbackward">
  <go href="#card3"/>
</onevent>

<card id="card1" title="card 1">
<p>
  <anchor>
     <go href="#card2"/>
     go to card 2
  </anchor>
</p>
</card>
<card id="card2" title="card 2">
<p>
   <anchor>
   <prev/>
      going backwards
   </anchor>
</p>
</card>
<card id="card3" title="card 3">
<p>
hello world!
</p>
</card>
</wml>