the topmost layer in the wap (wireless application protocol) architecture is made up of wae (wireless application environment), which consists of wml and wml scripting language.
- wml stands for wireless markup language 
- wml is an application of xml, which is defined in a document-type definition. 
- wml is based on hdml and is modified so that it can be compared with html. 
- wml takes care of the small screen and the low bandwidth of transmission. 
- wml is the markup language defined in the wap specification. 
- wap sites are written in wml, while web sites are written in html. 
- wml is very similar to html. both of them use tags and are written in plain text format. 
- wml files have the extension ".wml". the mime type of wml is "text/vnd.wap.wml". 
- wml supports client-side scripting. the scripting language supported is called wmlscript. 
wml versions:
wap forum has released a latest version wap 2.0. the markup language defined in wap 2.0 is xhtml mobile profile (mp). the wml mp is a subset of the xhtml. a style sheet called wcss (wap css) has been introduced alongwith xhtml mp. the wcss is a subset of the css2.
most of the new mobile phone models released are wap 2.0-enabled. because wap 2.0 is backward compatible to wap 1.x, wap 2.0-enabled mobile devices can display both xhtml mp and wml documents.
wml 1.x is an earlier technology. however, that does not mean it is of no use, since a lot of wireless devices that only supports wml 1.x are still being used. latest version of wml is 2.0 and it is created for backward compatibility purposes. so wap site developers need not to worry about wml 2.0.
wml decks and cards:
a main difference between html and wml is that the basic unit of navigation in html is a page, while that in wml is a card. a wml file can contain multiple cards and they form a deck.
when a wml page is accessed from a mobile phone, all the cards in the page are downloaded from the wap server. so if the user goes to another card of the same deck, the mobile browser does not have to send any requests to the server since the file that contains the deck is already stored in the wireless device.
you can put links, text, images, input fields, option boxes and many other elements in a card.
wml program structure:
following is the basic structure of a wml program:
<?xml version="1.0"?> <!doctype wml public "-//wapforum//dtd wml 1.2//en" "http://www.wapforum.org/dtd/wml12.dtd"> <wml> <card id="one" title="first card"> <p> this is the first card in the deck </p> </card> <card id="two" title="second card"> <p> ths is the second card in the deck </p> </card> </wml>
the first line of this text says that this is an xml document and the version is 1.0. the second line selects the document type and gives the url of the document type definition (dtd).
one wml deck (i.e. page ) can have one or more cards as shown above. we will see complete details on wml document structure in subsequent chapter.
unlike html 4.01 transitional, text cannot be enclosed directly in the <card>...</card> tag pair. so you need to put a content inside <p>...</p> as shown above.
wap site design considerations:
wireless devices are limited by the size of their displays and keypads. it's therefore very important to take this into account when designing a wap site.
while designing a wap site you must ensure that you keep things simple and easy to use. you should always keep in mind that there are no standard microbrowser behaviors and that the data link may be relatively slow, at around 10kbps. however, with gprs, edge, and umts, this may not be the case for long, depending on where you are located.
the following are general design tips that you should keep in mind when designing a service:
- keep the wml decks and images to less than 1.5kb. 
- keep text brief and meaningful, and as far as possible try to precode options to minimize the rather painful experience of user data entry. 
- keep urls brief and easy to recall. 
- minimize menu levels to prevent users from getting lost and the system from slowing down. 
- use standard layout tags such as <big> and <b>, and logically structure your information. 
- don't go overboard with the use of graphics, as many target devices may not support them. 
