( u+ U) v T [/ x O9 Z
WAP(wml)开发教程
/ s0 w# E9 r, `! s8 q& i) ]6 d# [WAP(无线应用协议)是在数字移动电话、因特网或其他个人数字助理机(PDA)、计算机应用之间进行通讯的开放全球标准。 它是由一系列协议组成,用来标准化无线通信设备,可用于Internet访问,包括收发电子邮件,访问WAP网站上的页面等等。
% f+ K* I% M( q' ~& IWAP将移动网络和Internet以及公司的局域网紧密地联系起来。提供一种与网络类型、运行商和终端设备都独立的移动增值业务。
通过这种技术,无论你在何地、何时只要你需要信息,你就可以打开你的WAP手机,享受无穷无尽的网上信息或者网上资源。如:综合新闻、天气预报、股市动态、商业报道、当前汇率等。电子商务、网上银行也将逐一实现。你还可以随时随地获得体育比赛结果、娱乐圈趣闻以及幽默故事,为生活增添情趣,也可以利用网上预定功能,把生活安排的有条不紊。
0 ^. P4 |- v7 m7 kWAP协议包括以下几层:
4 S- a2 w+ q0 o, Q2 F' E( p. ^4 P( Q8 h: _1、Wireless Application Environment (WAE)
2、Wireless Session Layer (WSL)
* c" Q2 }+ v7 u. v4 {3、Wireless Transaction Layer (WTP)
* O) T$ `0 N# |0 f e5 `: m4、Wireless Transport Layer Security (WTLS)
5、Wireless Transport Layer (WDP)
+ i" _% V' ^9 q" {( ~7 v2 x) f( }2 j其中,WAE层含有微型浏览器、WML 、WMLSCRIPT的解释器等等功能。WTLS层为无线电子商务及无线加密传输数据时提供安全方面的基本功能。
WAP协议的诞生是WAP论坛成员多年努力的结果。它是针对不同的协议层定义了一系列协议,这些协议使得各方面的厂商和公司可以协同工作,开发无线通信网络的应用。目前有超过100个成员加入WAP论坛,包括有终端和基础设备的制造商,有移动通信的网络运营商,有业务提供商,有软件公司,也有网络内容提供商等,共同为移动设备开发服务和应用。
. Y$ _( m5 q2 {! E4 H" k但是,目前由于无线网的带宽等等因素的限制,WAP手机的在多媒体上的应用如:可视会议、多媒体教学等等,还须一段时日。
WAP规范还在不断地完善,WAP论坛成员们在加紧开发功能完善的WAP设备,这无疑加快其在无线因特网综合服务领域的扩展速度。
关于WAP有几点,应该注意一下:
1.WAP不只是将手机带入IP/Internet网络
WAP规范考虑了很多无线网络和手机的特性。即便是3G的手机也无法把屏幕做的象通用计算机一样,来浏览HTML页面。直接接入IP网,9110在98年就可以,但是应用呢,不可能Nokia, Motarola, Ericsson推出手机时各自定义一套应用。
象WWW一样,在规范推出以前,已经有了很多基于IP网络的应用,包括一些做的很好的软件。但Internet遍地开花却是在WWW规范推出之后。WAP很大的意义在于统一的标准。
4 |* S6 b9 P) ]WAP和无线IP网络并不矛盾,WAP协议规定,若承载基于IP,WDP就是UDP。等无线IP网络普及,若认为上面几层太繁琐,最多是WAP协议中间几层略掉(其实也没太多东西)。
2.WAP应用模式很多
只要手机和网络支持统一标准,业务发展是不可限量的。这一点就不多说了。
3.WAP是发展的
WAP规范不仅定义了和Internet结合部分,还定义WTE,及话音部分,可以说发展还早呢。要是以后通讯核心网建起来,话音业务没准都采用WAP来实现。
, O( q F& [ j# a5 f- rWML学习(一)
( W0 C8 F u% b- B概述
9 M5 Z/ Z8 H* c9 Q# R5 }WML(Wireless Markup Language - 无线标记语言)这种描述语言同我们常听说的HTML语言同出一家,都属于X ML语言这一大家族。HTML语言写出的内容,我们可以在我们的PC机上用IE或是Netscape等浏览器进行阅读,而 WML语言写出的文件则是专门用来在手机等的一些无线终端显示屏上显示,供人们阅读的,并且同样也可以向使用者提供人机交互界面,接受使用者输入的查询等信息,然后向使用者返回他所想要获得的最终信息。
基本规则
* WML使用XML文档字符集,目前支持 Unicode 2.0,和HDML不同, WML的所有标签,属性和规定的可接收值必须小写,CARD的名字和变量也是区分大小写的。和HDML一样,对于连续的空字符,只显示一个空格。标签内属性的值必须用“或者‘括起来,属性名,=和值之间不能有空格。对于不成对出现的标签,必须在 》 前加 / ,比如《br/》。在对变量的引用上和HDML基本相同,有:
% q/ j) E }) @! X4 f8 ~9 T& z* |( q% z
| 以下为引用的内容: + U; g5 m' j# t+ ]! J) p% w4 A0 O $(var1:esc) $(var1:noesc) $(var1:unesc) |
三种形式,具体含义参见前面HDML的相关部分。在对保留字符的处理上也基本相同,对应的取代字符有:
| 以下为引用的内容: - u" }! U' r" x' \, r 《 《 3 L; m/ | o/ S/ Z7 W4 }》 》 - f/ N1 t2 t- ?- y4 s’ ' 9 c# h3 N: V) D5 L" n6 [” “ " h4 j R7 K. ^5 l6 H& & ' A7 Z. ?/ s* f2 K( p$ $$ ' D$ M8 O3 m9 I空格 - - |
这里要指出的是在URL的传递过程中,用来连接参数的 & 必须转化为 & 。
- p1 e% q/ z$ S3 X$ Y9 p1 o3 YWML学习(二)
基本格式和文件头
/ g6 p( }/ t0 f7 Y( A: T) cwml文件的一般格式:
4 F$ `! T/ F% n1 `6 Q
| 以下为引用的内容: 《?xml version=”1.0“?》 3 r# g) W. K( l' W! _' l9 o4 b《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 ' e7 V/ b3 N- G' y《wml》 3 l# D ]3 C" w' x( T3 d% h《head》 《access/》 : x! b0 f3 n6 O4 [6 {0 J" t6 I$ p/ i《meta.。../》 《/head》 1 _5 B" m8 r& t2 [ l《card》 0 ~4 @ n# m+ _) o4 C" rSome contents.。. 《/card》 《wml》 |
结构看上去和HTMl文件很类似,对于每一个DECK,在其文档开头必须指明以下的类型声明:
| 以下为引用的内容: 《?xml version=”1.0“?》 《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 |
千万注意字母的大小写。对于一个DECK,其文件大小最好不要超过1.2K。
《wml》标签和HTML中的《html》标签一样,用来表明这是一个 WML的DECK,它有一个可选的xml:lang属性来制定文档的语言,比如《wml xml:lang=”zh“》表示文档语言为中文。
. o3 c* _; o4 P9 M& _2 n和HTML一样《head》标签包含了该DESK的相关信息。《head》 标签之间可以包含一个《access》标签和多个《meta》标签。
《access domain=”域“ path=”/路径“ /》相当于HTML中的《BASE》标签,指定该DECK的访问控制信息,它用两个可选的属性,domain用来指定域,默认值为当前域, path用来指定路径,默认值为”/“,即根目录。由于 《access》单独使用,所以要用/结尾,以后对于类似的情况不再赘述。
《meta 属性 content=”值“ scheme=”格式“ forua=”true|false“/》 和HTML中的类似,提供了该DECK的meta信息。属性是必选的,包括一下三种情况name=”name“ UP.Link Server忽略meta数据
http-equiv=”name“ UP.Link Server将meta 数据转为 HTTP 响应头(同HTML)
user-agent=”agent“ UP.Link Server 直接将 meta 数据传给手机设备,content属性也是必选的,其内容根据属性而定。scheme属性目前尚不支持。forua 为可选属性,指定在该wml文件传到客户端之前,《meta》标签是不是被中间代理删除(因为传输的协议可能改变),默认值为false。
& k, D2 E \! \+ j; S0 r2 h2 F7 j目前支持的meta数据:
) z7 Z" r& u, b7 ]: l& M《meta http-equiv=”Cache-Control“ content=”max-age=3600“/》指定DECK在手机内存缓存中的存储时间段,默认的为30天(除非内存耗尽),在该期间, 手机对于访问过的DECK直接从缓存里调用。如果信息是对时间敏感的,可以用max-age指定DECK在缓存里的生存期,最小单位是秒, 如果指定为0, 则每次都需通过连接服务器来调用该DECK。
$ U0 s! j' _' S《meta user-agent=”vnd.up.markable“ content=”false“/》和《meta user-agent=”vnd.up.bookmark“ content=”指定的URL“/》 类似于普通浏览器的书签功能。当用户将一个CARD做了书签后,手机浏览器首先用一个标记记录该CARD, 这个标记默认的是《card》标签中的title属性(以后会讲到),然后当用户选择了该书签以后,浏览器就会打开被记录的URL。但是因为在默认的情况下,手机会记录所有的DECK,所以,一般《meta》被用来使手机不要记录当前的URL,即《meta user-agent=”vnd.up.markable“ content=”false“/》。此外, 如果要为书签指定不同于当前DRECk的 URL,用《meta user-agent=”vnd.up.bookmark“ content=”指定的URL“/》。
4 n% q7 D) I8 J: I$ N一个DECK可以包含多个CARD,每个CARD的内容可能不止一屏显示,注意DECK,CARD和屏幕显示范围的关系。一个CARD用《card》和《/card》包含。《card》可以包含以下可选的属性:
& n v4 ]& V3 H' H1 ^《card id=”name“ title=”label“ newcontext=”false“ ordered=”true“ onenterforward=”url“ onenterbackward=”url“ ontimer=”url“》
*id属性用来指定CARD的名字,可用来在CARD间跳转,相当于在HTML中在页内跳转时用《A NAME=”jumpHere“》。
*title属性用来作为书签的标记,该属性一般不会显示在屏幕上。
*newcontext属性,默认值为false, 用来指示当跳转到本CARD时,手机是不是要清除以前保留的信息,包括变量,堆栈里的历史记录,重新设置手机状态等。
*ordered属性,默认值是true,表明该CARD里的内容是按固定的顺序显示, 还是按用户的选择来显示。这点和HTMl不同,CARD 页面里的内容可以按一定的顺序显示,默认的是按线性顺序显示,即按代码的顺序, 但是,要注意的是,以下三个标签必须按以下顺序来写《onevent》《timer》《do》, (这和以后要讲的“事件”有关)。这样做是为了方便填表单,当ordered设置为true时,如果一个表单的内容不能在一屏里显示完,就分成多屏显示;当ordered设置为false时, 手机可以显示一个概要CARD来总结有效的选项,用户可以从中选取表单选项来填写。
*onXXX属性,类似于HTML标签中的onXXX属性,用来捕捉事件,当事件被触发时执行指定的操作(任务),在这里是转向某个URL。
3 |4 B. N- W5 }: lWML学习(三)
% s7 S. c" S1 G# E( E a显示文本
( g: @7 [) B( D( Y+ s* j7 E Z) U在文本的显示上WML基本和HTML相同。文字段落包含在《p align= ”alignment“ mode=” wrapmode“》和《/p》之间,align属性指定该段文字的对齐方式,默认的是left,其他可选择right和center;mode属性指定当一行显示不下所有的文字时是否自动换行,默认的是自动换行wrap,如果选nowrap,则在一行中显示,浏览器会通过类似于水平滚动条的机制来显示所有文字。
换行标签也一样为《br/》,这里先替一下,在标单中如果有多个《input》或者《select》,其间不要用《br/》,否则会使手机浏览器认为是断点而把表单分页显示。
文字的修饰标签有《b》、《i》、《u》、《em》、《strong》、《big》和《small》,意义和HTML里的相同。
表格的显示标签也和HTML相近,使用《table title=”name“ align=”left|right|center“ columns=”列数“》、《tr》和《td》来显示,《table》的title属性用来给表格取个名字,columns属性指定表的列数,不能为0,可选的align属性和前面提到的一样是对齐方式。表格中可以包含文字和图片。
test1.wml
. q$ y$ q9 Z& Y) E+ K5 B- o, ?) t--------------
+ Y% D) H6 o! v4 j5 m
| 以下为引用的内容: . T0 `2 d) E2 D 《?xml version=”1.0“?》 《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 : R" t W) l/ k《wml》 《card》 《p align=”center“》 4 t/ V) S% e! Y: S《i》Hello《/i》《br/》 / k( }& \3 ~0 m$ W《b》《i》World!《/i》《/b》 《table title=”mytable“ align=”right“ columns=”2“》 * a* o7 A5 `) A8 m' u《tr》 《td》1-1《/td》 0 \# L: T( }# b- o《td》1-2《/td》 《/tr》 ; U& u) V, N' K; H《tr》 《td》2-1《/td》 * Z6 U6 M8 B, Z. f6 F《td》2-2《/td》 《/tr》 # U1 ~4 T5 U6 L- f/ G《/table》 《/p》 《/card》 5 P0 n* u V6 b @$ a+ h《/wml》 |
显示图片
( o7 k0 F+ B1 G6 {5 s0 {) Z显示图片(1位黑白BMP图片)的标签一样类似于HTML,《img alt=”text“ src=”url“ localsrc=”icon“ align=”left“ height=”n“ width=”n“ vspace=”n“ hspace=”n“/》,属性中alt和src是必须要有的,其他可选。另外要注意的是《img》要放在《p》里,不能放在《do》和《option》等功能健标签和选单标签里。
$ N+ a& \2 w6 y! q9 C$ V0 q*alt属性用来指定当手机不支持图片显示时用来显示的文字。
*src属性指定图片的URL,但当有了以下的localsrc属性时,手机浏览器就忽略src属性。
5 H) k* I7 g8 q*localsrc属性用来指定显示存在手机ROM中的图标,如果找不到,则到UP.Link Server上去找。
*可选的align属性用来表明图片同当前行文本的对齐方式,默认值为bottom,可选to和middle。
3 @% {4 \8 z4 w6 l4 `*height、width、vspace、hspace属性分别指定图片的长宽和距环绕文字的间距,目前不是所有的WAP手机都支持这些属性。
% O, y7 {% [3 @1 ?% }" c [9 H& w. Ptest2.wml
+ F0 c, j+ x2 |! d' {2 b0 H---------------
0 o) q: j% j5 U, K ?, B" K% f1 R
| 以下为引用的内容: ' n- e$ ^! K0 r, |! J ` 《?xml version=”1.0“?》 , l, Q3 j7 v. _: \$ p. |& |《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org /DTD/wml_1.1.xml“》 《wml》 《card》 《p align=”center“》《img alt=”:)“ src=”xxx.bmp“ localsrc=”smileyface“/》《/p》 《/card》 《/wml》 |
WML学习(四)
1 i4 d; l( Z6 Q1 w! j7 q9 a- ^: c0 \锚和任务
连接是 HTML 页面里最基本的功能, 在 WML 里也一样用 《a href=”url“ title=”label“》 和 《/a》来包括用来建立连接的文字,必选属性href指定了要打开的URL,可选的title属性给该连接取个标记名字,这个名字将作为软按钮之一的ACCEPT键(详见以前的HDML入门文章)的标记显示在屏幕的软按钮区,所以通常可以将属性作为提示文字是用。
然而,以上的连接在WML里只是任务的一种情况,为了能够使用其它任务,所以引进了新的标签《anchor title=”label“》任务标签 文本《/anchor》,《a》其实是当任务标签为
, n; I' [ I) O0 h《go/》时的简单表示方式。
6 w+ w5 U% z6 t, i4 b& |/ `test3.wml
---------------
0 _- [$ e% O9 r j
| 以下为引用的内容: / Z& A: i1 Y: [ W 《?xml version=”1.0“?》 《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org /DTD/wml_1.1.xml“》 - Q/ y7 T- o) p0 V2 m& K《wml》 . o3 d7 x; |0 Q2 h8 p7 _《card》 F9 ~( f h1 b9 ~0 \1 y! F《p》 * u1 F* ]. t: d) X$ W# I4 v《anchor title=”Link1“》《go href=”test1.wml“/》News《/anchor》《br/》 《a title=”Link2“ href=”test2.wml“》Sports《/a》 《/p》 《/card》 + r8 F0 P2 @' u' P《/wml》 |
WML里的任务标签有以下几种,除了用于《anchor》,还可以用在事件中:
0 W: c# E r* A! D( @1)《go》用来指示浏览器显示指定的URL,包括DECK的第一个CARD或者指定的CARD。语
法如下:
; c9 u: j& s# T: l- I" W+ r0 q. N& H* F( U( a1 ]' E
| 以下为引用的内容: 《go href=”url“ sendreferer=”false|true“ method=”get|post“ accept-charset 5 D9 P8 R* r0 h; p- @9 s" s9 ?, w=”charset“》 6 L- k* N- V/ X# `" K* n《postfield name=”name“ value=”value“/》 6 ^0 t$ V4 Z( }7 V0 {% _: c. w《setvar name=”name“ value=”value“/》 《/go》 |
其中href属性为必选,其他为可选。sendreferer属性表示是否传递调用href所指定的URL的页面的URL,也就是当前页的URL,即 HTTP 头中的HTTP_REFERER,默认值为false,可选值为true。method和HTML中的表单FORM的method属性一样,指定表单是以get的方式还是post的方式递交,以便cgi处理,默认的值为get,但如果未指定method但《go》《/go》间存在《postfield》,手机自动以post方式传递。accept-charset 属性可覆盖在HTTP头里指定的字符集,可以写多个字符集,如accept-charset=”UTF-8,US-ASCII, ISO-8859-1“。
《postfield name=”name“ value=”value“/》可以看作是HTML表单FORM中的《INPUT TYPE=”HIDDEN“ NAME=”变量名“ VALUE=”值“》,通过它可以向指定的URL传递以“变量名/值”形式的数据。name和value属性都是必选的。注意只有这里的变量是用来递交给CGI程序的。
' n/ p" m8 b1 ~3 H& B& I2 J. V* t5 p除了《postfield》,还可以在《go》和《/go》间加入一句或者多句《setvar name=”name“ value=”value“/》,该语句的意思是,当触发某一事件时,给变量赋值。
要注意的是,当《go》和《/go》之间没有任何语句时,要用《go/》的形式,这点比较特别,比如《anchor title=”Link1“》《go href=”test.wml“/》News《/anchor》。
2)《prev》用来将当前页面的URL压入URL历史堆栈,并打开此前的URL,若该URL不存在,则《prev》无效。语法类似《go》:《prev》《setvar name=”name“ value=”value“/》《/prev》,《prev》和《/prev》之间可加入一句或多句《setvar name=”name“ value=”value“/》,若不加,则必须变成《prev/》的形式。
3)《refresh》用来刷新当前的页面,从而使得页面内的变量刷新,语法为《refresh》《setvar name=”name“ value=”value“/》《/refresh》。
% e6 a; g, C- \: `) @7 [! v& s2 u6 R4)《noop》,表示什么也不做,该标签不能用在《anchor》中,一般用在覆盖DECK级的《do》(以后会说明)。
WML学习(五)
* L8 H' {: x2 h# c# J- l显示表单
( T) M: U0 l1 @3 b类似于HTML的《FORM》,《fieldset》可用来包括一组表单选项,但不是必须的。前面说过,当《card》的ordered设置为false时,手机可以显示一个概要CARD来总结有效的选项,方便用户从中选取表单选项来填写,概要CARD就是根据《fieldset》和独立的输入框《input》以及选单《select》来总结的。语法为, 《fieldset title=”label“》表单内容《/fieldset》,可选的title属性除了可用来表示表单的名字外,还在概要CARD里作为选择项的标题。表单内容可以是嵌套的《fieldset》,输入框《input》,选单《select》和必要的提示文本。
《input name=”variable“ title=”label“ type=”type“ value=”value“ default=”default“ format=”specifier“ emptyok=”false|true“ size=”n“ maxlength=”n“ tabindex=”n“/》,用来输入文本,除了name属性是必要的,其他可选。
9 C/ [3 e I- C0 v( a: ~2 d/ ^*name属性,指定了用来存储该输入文本的变量名字。
0 f. w, T! v3 C4 F5 i*title属性,该输入框的名字,同样可被用来作为概要CARD页中的选项名。
7 t6 L; V o: ]& A& G M6 q*type属性,默认值为text,如选择password,则输入的数据显示为*。
*value属性,在语法和行为上等同于下面的default属性,*default属性,指定输入框的默认值,即name属性指定变量的默认值,当用户输入新值时,该值无效,如果该值不符合以下format属性的规定,则手机也忽略该默认值。
+ K% D8 ?& N. P. K* \*format 属性,用来格式化输入的数据,可用的标记如下,使用时可用“一位数字标记”和“*标记”的形式,前者代表N个标记型字符,如3X, 后者代表任意个(小于maxlength属性的值)标记型字符。
4 y5 u' ] f: m$ T# A a. q标记 描述
! W0 e0 T2 `7 B6 N; q# fA 任何符号或者大写字母(不包括数字)
/ G7 O2 J8 C3 G7 L& P. z1 ma 任何符号或者小写字母(不包括数字)
N 任何数字(不包括符号或者字母)
X 任何符号、数字或者大写字母(不可改变为小写字母)
x 任何符号、数字或者小写字母(不可改变为大写字母)
; E) z4 m% l4 @ ~7 SM 任何符号、数字或者大写字母(可改变为小写字母)或者多个字符,默认为首字大写
; g& l2 a$ h9 D" \" Sm 任何符号、数字或者小写字母(可改变为大写字母)或者多个字符,默认为首字小写
*maxlength属性,指定了用户可输入的最大字符长度,最大限制为256个字符。
*emptyok属性,表示用户可否不填输入框,默认为false,即要填。
3 T" t, G3 {$ F4 _3 c9 W* Y2 v' V4 C*size属性,输入框显示长度,目前未被支持。
*tabindex属性,类似于在HTML表单中按TAB键后,焦点落在哪个选项上,该值决定了这个选择顺序,数字大的排在后面。目前未被支持。
test4.wml
将上例《card》中的odered的值改为”true“试试看,然后再在《p》和《/p》内加入《fieldset title=”field1“》和《/fieldset》试试看。
《select》选单类似于HTML表单中的《SELECT》,《select》和《/select》间可包含《optgroup》和《option》标签,语法如下,所有属性都为可选:
《select title=”label“ multiple=”false|true“ name=”variable“ default=”default“ iname=”index_var“ ivalue=”default“ tabindex=” n“》
《optgroup title=”label“》选单内容《/optgroup》
《option title=”label“ value=”value“ onpick=”url“》
事件或者文本
《/option》
《/select》
' u- N1 m2 v* {. U* J% i) t*title属性,如以上《input》的title属性。
*multiple属性,指定用户可否进行多项选择,默认值为false。
*name属性,用来存储用户选择项的变量名,其值为 《option》标签的value属性,若用户没有选择又没有用 default 属性指定默认值, 则手机将改变量赋值为空字符串”“,对于多项选择,每个值用“;”分开。
& c5 o' H9 j" t! ~9 w*default属性,可为name属性指定的变量赋默认值。
* J( W9 C% v' G. Q. Z( h( a1 W0 W*iname属性,用来记录用户选择项的位置,相应的值从 1 开始。 若没选,则该值为0。
*ivalue属性,用来记录默认值所在的位置。
$ }( g8 C9 ~' N2 a" P《optgroup》可用来将多个《option》分组,《optgroup》和《/optgroup》间还可包括《optgroup》和《option》,该标签目前尚未被支持。
《option》,类似于HTML中选单的《OPTION》,用来表示选单的可选项。《option》和《/option》间可包括事件(见下节)和选单的显示文本。《option》 的属性为可选,其中value属性用来提供值,当选到该项后,将该值赋给《select》 的name属性所指定的变量。onpick属性,用来指定用户选到该项并按ACCEPT键后所打开页面的URL。
test5.wml
---------------
| 以下为引用的内容: 《?xml version=”1.0“?》 & p" K) j$ q1 K) n《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 * b9 o5 t# ]7 R: D4 Y3 ~+ ?《wml》 7 }2 [' f" g! g《card id=”card0“ ordered=”false“》 《p》 Please select a city.。. 《select title=”Cities List“ name=”city“》 ' B B" p7 y( o0 F+ I9 z《option title=”Beijing“ value=”c1“》Beijing《/option》 《option title=”Shanghai“ value=”c2“》Shanghai《/option》 0 t0 v( |& M& o. T5 {3 r' k1 E《option title=”Hongkong“ value=”c3“》Hongkong《/option》 . `! S: E$ c: D0 c7 ^+ {& d《/select》 Please select columns.。. 《select title=”Column List“ multiple=”true“ name=”col“》 《option title=”Hot News“ value=”l1“》News《/option》 + I" y, e0 v4 {2 W9 _! o" A《option title=”Cool Sports“ value=”l2“》Sports《/option》 4 e' j+ F7 c* E; z$ j% z0 {9 s T《option title=”Pop Enter,,,“ value=”l3“》Entertainment《/option》 《/select》 9 e2 @1 g" D4 s% [& q《/p》 0 Y' Q8 g% U; F9 U' L《/card》 《/wml》 |
, v% g6 B& q; p% U2 c% x
WML学习(六)
事件
5 O# E. W; b# g& M0 B9 y. EWML的事件基本上分为两大类,一类是键盘(包括软硬按钮)输入事件,用《do》标签来处理,另一类是相关页面内部的事件,用《onevent》标签来处理。
《do》的语法如下:《do type=”type“ label=”label“ name=”name“ optional=”false|true“》任务《/do》,任务就是以前提到的四种任务。《do》的属性中,type是必选的,其他为可选。
*label属性,指定了软按钮在屏幕上的显示文本。目前type属性为delete,help,prev时该属性无效。
; X, y) R1 q/ R*name属性,为《do》取个名字,同一的CARD里的《do》不能重名。如果CARD级的《do》和DECK级的《do》同名,则覆盖DECK级的《do》。
7 _6 K7 G6 d- j8 @. S" i8 q2 d6 ^" |*optional属性,指定手机是不是可以忽略这个事件,默认值是false。
& T- D& d8 ?3 |4 ~*type属性,指定触发的事件,具体如下;
5 [7 S f3 M, V" r- g2 Atype值 触发原因
accept 调用ACCEPT按钮机制
) d; [. _3 j1 K. |8 ]7 ydelete 调用DELETE按钮机制
$ _( \! ^* o. q, P3 h1 h! uhelp 调用HELP按钮机制
options 调用选择按钮机制
prev 调用PREV按钮机制
2 Y+ E) O! s% k5 v, h" ~6 Treset 调用清除和重新设定手机状态时的RESET机制(目前不支持)
; P- u* C+ v F5 N% l. {unknown 调用unknown机制,等于type=”“(目前不支持)
" G' c7 M7 t9 m, G6 cvnd. co-type 调用厂商特定的机制(目前不支持)
+ q% M% S; v0 G0 GX-*, x-* 供以后使用(不保留)(目前不支持)
test6.wml
---------------
4 [0 n$ }5 ^+ }+ K$ e
| 以下为引用的内容: 《?xml version=”1.0“?》 0 `; N( |% E( C0 ^, Y《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 《wml》 1 G2 _ u# y1 O2 F% Y! D《head》 《meta http-equiv=”Cache-Control“ content=”max-age=0“/》 5 f; m: R* D/ ?《/head》 《card id=”card0“ ordered=”false“》 [ H: U8 |8 M《do type=”accept“ label=”InputName“ name=”do1“》 《go href=”#card01“/》 《/do》 8 }. V, ^' r* U/ U% \1 s+ G5 _) Y《p》 NAME:《input name=”userName“ title=”User Name“ type=”text“ format=”*M“ emptyo k=”false“ maxlength=”12“/》 % i; @1 e, o( ^+ {9 ^/ z《/p》 0 ^8 T/ R! e# W, p+ S* _/ {《/card》 . Z5 G5 F2 z5 Y" k/ P& l) W) R《card id=”card01“》 《p》 You name is $(userName:noesc)。 1 `7 d6 X* q: `' y% F( D《/p》 《/card》 6 W, y4 ^! ~8 r- u: {《/wml》 |
《onevent》的语法如下,《onevent type=”type“》任务《/onevent》,必选属性type的取值如下:
type值 如果用户执行了以下操作就执行任务
onpick 用户选择或不选一个《option》项时。
/ l$ t' z% ]2 }- Aonenterforward 用户使用《go》任务到达一个CARD时。
onenterbackward 用户使用《prev》任务返回到前面的CARD时,或者按BACK按钮时。
( \, j5 o) x* E9 c: s0 N1 lontimer 当《timer》过期时。
5 ?! {% o; \% `, Etest7.wml
---------------
- P. o( j3 H6 [& Q2 {
| 以下为引用的内容: 《?xml version=”1.0“?》 2 V1 M7 P \* n) k《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 《wml》 B8 R3 k+ ~# I5 ~4 u$ A《head》 ) q, Z7 z. R% t( Q! A( B《meta http-equiv=”Cache-Control“ content=”max-age=0“/》 《/head》 《card id=”card0“ ordered=”false“》 《p》 ( k9 Q B6 T Y" O" Q" NPlease select a city.。. 6 c. s, {; P& a$ n《select title=”Cities List“ name=”city“》 * ?5 ~% B* P n: b; |《option title=”Beijing“ value=”Beijing“》 0 G9 x8 ~- L7 J9 W- B《onevent type=”onpick“》 " B, q8 u6 H' z, C& ~# }" ~' a5 q《go href=”#card01“/》 《/onevent》Beijing《/option》 7 e! b" l) l$ l" }+ _1 i5 u7 k《option title=”Shanghai“ value=”Shanghai“ onpick=”#card01“》Shanghai《/option》 . J" t# D4 l5 w- L/ }* H《option title=”Hongkong“ value=”Hongkong“ onpick=”#card01“》Hongkong《/option》 9 R& ], f5 x H8 l) ^《/select》 《/p》 * Q' `: i$ S7 @& V# J8 j《/card》 ) g. _! e0 Z1 U' X* d% F《card id=”card01“》 《p》 You are Living in $(city:noesc) 8 t0 Y/ k, ~* q) w《/p》 , _3 {. J' d4 I, f" g; ^《/card》 9 E7 u2 D. S' @4 Q《/wml》 |
《timer/》可以用来在用户不进行任何操作的一段时间后,自动执行一个任务,任何激活CARD页面的任务和用户操作都会启动《timer/》,而任务进行时,《timer/》就停止。
每个CARD只能有一个《timer/》,一个《timer/》只能触发一个任务。语法如下:《timer name=”variable“ value=”value“/》,其中name为可选属性,指定为一个变量名,当退出该CARD时,该变量存储此时定时器的值,当定时器超时时,手机将该变量设为0;value为必选属性,用来设置定时器的定时值,最小单位为0.1秒。
$ X0 o( o- ?+ F3 @1 a. |. _test8.wml
---------------
! [4 ^7 s# r, Z( p0 ^( c& ^9 `
| 以下为引用的内容:
《?xml version=”1.0“?》 ; s) A; v# }# ~0 R《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 《wml》 《head》 《meta http-equiv=”Cache-Control“ content=”max-age=0“/》 《/head》 《card id=”card1“ ontimer=”#card2“》 《timer name=”time1“ value=”50“/》 《p align=”center“》 " t" [/ _% S2 P8 zAfter 5s, goto card2 《/p》 《/card》 《card id=”card2“》 《onevent type=”ontimer“》 1 z4 ^# ]1 P+ v/ c, z《go href=”#card1“/》 " n3 x: ]7 s ]4 v" f5 S- ~( v《/onevent》 3 t+ M j. v* k- T+ D" }2 Q《timer name=”time2“ value=”50“/》 9 \% C9 n0 V& u! Y( _6 w7 A, P《p align=”center“》 2 H# b* u! p1 O( X! a; dHere is card2! 《/p》 《/card》 《/wml》 |
再提一下,《onevent》 《timer》 《do》三者必须按以上顺序写。
此外在DECK级还可以加入《template》,用来将事件捆绑在DECK级上,语法如下:
- ~% p9 f" q0 V8 c3 \《template onenterforward=”url“ onenterbackward=”url“ ontimer=”url“》
《do》或者《onevent》
5 |7 \% z) T q5 i6 c4 i《/template》
1 o; J9 G ^4 C: F& W* htest9.wml
---------------
2 H: y; u8 k8 }8 m. r0 [) Y+ l+ X
| 以下为引用的内容: # E+ u1 T: q+ \ 《?xml version=”1.0“?》 ( T% A0 @1 u- i. P1 n6 i《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 《wml》 $ l3 Z+ n5 f: j; x% g' b; s" f《head》 《meta http-equiv=”Cache-Control“ content=”max-age=0“/》 / t- S6 K% m, h7 R. q$ a% E《/head》 《template》 《do type=”accept“ label=”deckPress“ name=”do1“》 《go href=”#card01“/》 《/do》 《/template》 《card id=”card0“ ordered=”false“》 9 g# Z2 U: [5 Q5 J0 \, S2 ~《do type=”accept“ label=”cardPress“ name=”do1“》 《go href=”#card02“/》 ' v, }2 h) |. p. k I- i% g5 E8 b《/do》 ! z6 u x+ @; h- q* _/ N2 V; }# H; G《p》 1 H f, K9 [# E# D Y* }& VPress ACCEPT.。. ! C' d! D3 B6 U8 ]. J$ L: T* K0 E7 Z《/p》 《/card》 7 M, z2 w% p6 \3 R4 {! F《card id=”card01“》 * n; S$ ^& I) v5 a+ ]! O& d- E《p》 Here is card01 ' @7 |1 S; I7 d+ k《/p》 《/card》 - S$ E, ^! J: X$ r《card id=”card02“》 《p》 Here is card02 《/p》 《/card》 《/wml》 |
WML学习(七)
7 u2 u- m9 b/ e4 m; BCGI编程
; i* u+ K5 h! q- o8 a: j% Z1)在WEB服务器上添加WML的MIME类型
& C. x% n: k" z' M" l: ?对于IIS4,可在其管理器里的站点属性中加入新的MIME类型,后缀.wml和 MIME类型text/vnd.wap.wml。
) y5 ]4 \" j* e" L5 N O对于PWS,可修改注册表,先在 HKEY_CLASSES_ROOT层加入主键.wml,再加入串值Content Type为text/vnd.wap.wml,然后在HKEY_LOCAL_MACHINE\Software\CLASSES\MIME\Database\Content Type\中加入主键text/vnd.wap.wml,再加入串值Extension为.wml。
以前提到的HDML也用类似的方法。
2)以http方式访问wml文件
: {4 }8 Z# n A. Z0 S. ?在手机浏览器的URL栏里输入http://localhost/test.wml,就可以访问WML文件了。
+ x: `- l b* o3 ]& {3)CGI设计
9 g* a& ~$ v, T9 H. U, r/ L! e- O和普通CGI变成的方式差不多,只是返回结果时,先要输出Content-Type为text/vnd.wap.wml,然后再输出WML内容。
]) o# x4 G, ]2 W; }% ~5 @test10.wml
% ~% ?3 K& ]% o. M---------------
# C% ~4 B' l6 O8 d
| 以下为引用的内容: : E8 ~& n d4 m0 K- F' t 《?xml version=”1.0“?》 《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 : C$ Y: @" S0 V《wml》 ( Z- u; S" S' |% s1 B2 F8 w( J9 G3 E《head》 8 q- j+ F( _$ o e/ z, W《meta http-equiv=”Cache-Control“ content=”max-age=0“/》 《/head》 《card id=”card0“》 ( I& _2 E! o6 S5 _《do type=”accept“ label=”Input Name“ name=”do1“》 : w7 I( H. R: l: O$ A" J' N& s( t《go href=”http://localhost/test.asp“ method=”post“》 《postfield name=”uid“ value=”123456“/》 - u* d7 T8 u1 l, Y2 D( p2 j《postfield name=”uname“ value=”$(userName:esc)“/》 ! y) v) H/ f1 h0 S& T) w《/go》 《/do》 《p》 $ i7 n' H* C! @. {NAME:《input name=”userName“ title=”User Name“ type=”text“ format=”*M“ emptyok=”false“ maxlength=”12“/》 " \% H! E t1 U" T《/p》 《/card》 test10.asp ! W. Q: O$ K8 v. S- u' w! `( z--------------- 《% uid=Request.Form(”uid“) * b! L+ p- g& T/ C* }* m) [userName=Request.Form(”uname“) & t# r9 l* m2 D' r7 ~$ CResponse.ContentType=”text/vnd.wap.wml“ 8 c% U1 q- p3 D' i P- \( O%》 " K6 Q) m8 y- `( B/ U6 H* o《?xml version=”1.0“?》 《!DOCTYPE wml PUBLIC ”-//WAPFORUM//DTD WML 1.1//EN“ ”http://www.wapforum.org/DTD/wml_1.1.xml“》 《wml》 7 A1 e3 S5 L H$ m( m《card》 《p》 USERNAME:《%=userName%》 USER__ID:《%=uid%》 3 W' x7 u1 ^7 G8 \《/p》 ( O1 L' Q, q# c3 R# \《/card》 《/wml》 |
WAP网站服务器配置
设置APACHE WEB SERVER
+ n' o P# k* u- u1 o不管是NT 还是UNIX 或LINUX ,都是修改 Apache 安装目录下的conf/mime.types文件在该文件中增加以下内容:
, t8 c5 B& M& G: Ytext/vnd.wap.wml .wml
! a5 W; A( W9 R2 m: P/ Qimage/vnd.wap.wbmp .wbmp
application/vnd.wap.wmlc .wmlc
text/vnd.wap.wmls .wmls
application/vnd.wap.wmlsc .wmlsc
1 @0 P* t* o$ m. a) x存盘
( y* F( u3 o1 q- r( |& l6 y5 D重新启动APACHE WEB SERVER 即可。
* B5 m- a- i# O' a基于WINDOW NT平台的IIS设置WAP SERVER
, X$ x4 o3 x* j; j$ P只要按照以下的简单设置,就可以让NT IIS成为WAP服务器,您可以撰写WML网页或者开发各种服务。
- n0 U" r: e, D3 f设定方式:(先确定NT Server已经安裝IIS了服务)
' V9 _- I7 |6 T8 q v& m* {执行NT操作系统下的【开始】/【程序】/【Windows NT Option Pack】/【IIS 4.0】/I
nternet服务管理员。
% F' v7 n8 O2 }3 v m# q" N% p; J在IIS服务管理员窗口內,点选主机电脑名称后,按鼠标右鍵,点选“属性”选项;
) m Y& b! W/ F1 r# V在属性窗后下部有一个文件类型按钮,单击此按钮,会出现文件类型界面;
单击‘新增类型’按钮,然后在相关的扩展名栏中填写 .wml ,在内容类型(MIME)栏中填写 text/vnd.wap.wml
单击‘确定’按钮
+ V$ F3 P( G% E2 l重复以上步骤将以下WML类型新增至MIME內:
相关的扩展名 內容类型(MIME)
; L2 H6 O7 @: L n% G" K.wml text/vnd.wap.wml
3 ?8 o( N2 g. N: V/ M.wmlc application/vnd.wap.wmlc
.wmls text/vnd.wap.wmlscript
: ?' r; f& _8 [. o7 M$ k& \' k# V.wmlsc application/vnd.wap.wmlscriptc
.wbmp image/vnd.wap.wbmp

| 欢迎光临 老秘网_材夜思范文 (https://laomiw.com/) | Powered by Discuz! X3.4 |