WML - Görevler

WML görevi, görüntülenecek bir şeyden ziyade tarayıcı tarafından gerçekleştirilecek bir eylemi belirten bir öğedir. Örneğin, yeni bir karta geçiş eylemi bir <go> görev öğesi ile temsil edilir ve ziyaret edilen önceki karta geri dönme eylemi bir <prev> görev öğesi ile temsil edilir. Görev öğeleri, eylemi gerçekleştirmek için gereken tüm bilgileri içerir.

WML, go görevi, ön görev, yenileme görevi ve noop alımları adı verilen dört WML görevini gerçekleştirmek için aşağıdaki dört öğeyi sağlar.

<go> Görevi:

Adından da anlaşılacağı gibi <go> görevi, yeni bir karta gitme eylemini temsil eder.

<go> öğesi aşağıdaki nitelikleri destekler:

Öznitelik Değer Açıklama
href URL Yeni kartın URL'sini verir. Göreli URL'ler mevcut karta göre çözülür
yöntem
  • get
  • post
Desteyi getirmek için kullanılması gereken yöntemi belirtir. Bu, HTTP'nin GET ve POST yöntemlerine karşılık gelen get veya post değerlerinden biri olmalıdır.

Kullanırken method="get", veriler bir istek olarak gönderilir? URL'ye eklenen veriler. Yöntemin dezavantajı, yalnızca sınırlı miktarda veri için kullanılabilmesidir ve hassas bilgiler gönderirseniz, ekranda görüntülenecek ve web sunucusunun günlüklerine kaydedilecektir. Bu yüzden şifre vb. Gönderiyorsanız bu yöntemi kullanmayın.

İle method="post"veriler, istek gövdesinde gönderilen verilerle istek olarak gönderilir. Bu yöntemin sınırı yoktur ve hassas bilgiler URL'de görünmez

gönderen
  • true
  • false
True olarak ayarlanırsa, tarayıcı istekle birlikte geçerli desteğin URL'sini gönderir. Bu URL, mümkünse göreli bir URL olarak gönderilir. Bunun amacı, sunucuların, hangi destelerin onlara bağlandığına bağlı olarak, desteler üzerinde basit erişim kontrolü gerçekleştirmesine izin vermektir. Örneğin, HTTP kullanıldığında, bu öznitelik HTTP Referer başlığında gönderilir.
karakter kümesini kabul et charset_list POST isteğinde sunucuya gönderilen verileri kodlayabilen virgülle veya boşlukla ayrılmış karakter kümeleri listesini belirtir. Varsayılan değer "bilinmiyor".
sınıf sınıf verileri Öğe için bir sınıf adı belirler.
İD öğe kimliği Öğe için benzersiz bir kimlik.

Aşağıda <go> elemanının kullanımını gösteren örnek verilmiştir.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="GO Element">
<p>
   <anchor>
       Chapter 2 : <go href="chapter2.wml"/>
   </anchor>
</p>
</card>
</wml>

Get Yöntemi kullanılarak verilerin nasıl yükleneceğini gösteren başka bir örnek

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="GO Element">
<p>
   <anchor>
      Using Get Method 
      <go href="chapter2.wml?x=17&y=42" method="get"/>
   </anchor>
</p>
</card>
</wml>

<setvar> öğesi kullanılarak verilerin nasıl yükleneceğini gösteren başka bir örnek.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="GO Element">
<p>
   <anchor>
      Using setvar:
	  <go href="chapter2.wml"> 
	      <setvar name="x" value="17"/> 
  	      <setvar name="y" value="42"/> 
	  </go>
   </anchor>
</p>
</card>
</wml>

<postfiled> öğesi kullanılarak verilerin nasıl yükleneceğini gösteren başka bir örnek

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="GO Element">
<p>
   <anchor>
      Using setvar:
	  <go href="chapter2.wml" method="get"> 
              <postfield name="x" value="17"/>
              <postfield name="y" value="42"/>
	  </go>
   </anchor>
</p>
</card>
</wml>

<prev> Görevi:

<prev> görevi, geçmiş yığınında daha önce ziyaret edilen karta geri dönme eylemini temsil eder. Bu eylem gerçekleştirildiğinde, geçmiş yığınından en üstteki giriş kaldırılır ve bu kart <prev> görevindeki herhangi bir <setvar> değişken ataması yürürlüğe girdikten sonra tekrar görüntülenir.

Önceki URL yoksa, <prev> belirtmenin bir etkisi olmaz.

<prev> öğesi aşağıdaki öznitelikleri destekler:

Öznitelik Değer Açıklama
sınıf sınıf verileri Öğe için bir sınıf adı belirler.
İD öğe kimliği Öğe için benzersiz bir kimlik.

Aşağıda <prev> öğesinin kullanımını gösteren örnek verilmiştir.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Prev Element">
<p>
   <anchor>
        Previous Page :<prev/>
   </anchor>
</p>
</card>
</wml>

Değişkenleri bir <prev> görevine dahil etmenin yararlı olabileceği bir durum, bir kullanıcı adı ve şifre isteyen bir oturum açma sayfasıdır. Bazı durumlarda, oturum açma kartına döndüğünüzde, kullanıcıyı yeniden girmeye zorlayarak parola alanını temizlemek isteyebilirsiniz. Bu, aşağıdaki gibi bir yapıyla yapılabilir:

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Prev Element">
<p>
   <anchor>
        <prev>
           <setvar name="password" value=""/>
        </prev>
   </anchor>
</p>
</card>
</wml>

<refresh> Görevi:

<refresh> görevi, gerçekten bir şeyler yapan en basit görevdir. Etkisi basitçe <setvar> elemanları tarafından belirtilen değişken atamalarını gerçekleştirmek, ardından mevcut kartı yeni değerlerle yeniden görüntülemek. <go> ve <prev> görevleri, yeni kartı görüntülemeden hemen önce aynı eylemi gerçekleştirir.

<refresh> görevi, çoğunlukla kart üzerinde bir tür "sıfırlama" eylemi gerçekleştirmek için kullanılır.

<refresh> öğesi aşağıdaki öznitelikleri destekler:

Öznitelik Değer Açıklama
sınıf sınıf verileri Öğe için bir sınıf adı belirler.
İD öğe kimliği Öğe için benzersiz bir kimlik.

<refresh> öğesinin kullanımını gösteren örnek aşağıdadır.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Referesh Element">
<p>
   <anchor>
         Refresh this page:
          <go href="test.wml"/>
          <refresh>
            <setvar name="x" value="100"/>
          </refresh>
   </anchor>
</p>
</card>
</wml>

<noop> Görevi:

<noop> görevinin amacı hiçbir şey yapmamaktır (işlem yok).

Bu görevin tek gerçek kullanımı şablonlarla bağlantılıdır

<noop> öğesi aşağıdaki nitelikleri destekler:

Öznitelik Değer Açıklama
sınıf sınıf verileri Öğe için bir sınıf adı belirler.
İD öğe kimliği Öğe için benzersiz bir kimlik.

Aşağıda, <noop> öğesinin kullanımını gösteren örnek verilmiştir.

<?xml version="1.0"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.2//EN"
"http://www.wapforum.org/DTD/wml12.dtd">

<wml>

<card title="Noop Element">
<p>
  <do type="prev" label="Back">
      <noop/>
  </do>
</p>
</card>
</wml>