|
<html>程序开发,操作系统,服务器,源码下载,Linux,Unix,BSD,PHP,Apach,asp,下载,源码,黑客,安全,技术社区,技术论坛'P:H:`4X3l
<head>5p4G4I8\-|2Z&X#~7@!u a%V
<title>Welcome to Tapestry!</title>TechWeb-技术社区)a7w#b$A/|4c2j&d
</head>!J,w,k/\&o$X+I
<body>tech.techweb.com.cn/?#f$T!X*C'a+h r
Hello <span jwcid="user">User Name</span>! Welcome to Tapestry! m+Z9i*[(V*j,Y;h
</body>程序开发,操作系统,服务器,源码下载,Linux,Unix,BSD,PHP,Apach,asp,下载,源码,黑客,安全,技术社区,技术论坛1K%\3G6J+U.H
</html>
+B.u4O.y3p.V$m
9g3y j3W*q#c,u这里你可能看上去觉得非常眼熟,这不就是一个普通的HTML网页吗?且慢,如果你仔细观察,会发现span标签多了一个新的属性jwcid,这正是 tapestry设计的精妙之处,它的表现层可以说几乎是99%的纯HTML,只是增加了一个jwcid属性,jwcid=”user”在这里的意思是在<span> … </span>之间放置一个名为user的组件。这里要指出的是jwcid属性不仅仅可以放在span标签内,它可以放在任何的HTML标签内,比如<title>、<body>、<form>等等,至于为什么要选<span>的原因是<span>标签不影响网页的输出效果,这就大大方便了美工人员,他们可以直接使用frontpage或dreamwaver来进行设计,而不像JSP那样无法在frontpage或dreamwaver中正常显示。程序开发,操作系统,服务器,源码下载,Linux,Unix,BSD,PHP,Apach,asp,下载,源码,黑客,安全,技术社区,技术论坛*O"s.G,}"l+y%d
TechWeb-技术社区6H;N7B+m*c'v
也许你会问,网页上输出的用户名明明是Jack嘛,为什么HTML模板中是User name呢?这是因为当tapestry一旦发现某个HTML标签有jwcid的属性后,它就会把这个标签当做一个组件来看待,至于标签里面的东西到底是原样输出或忽略就要依照那个组件的类型而定了,在这里我们的user组件实际上是一种Insert类型的组件,因此会把<span>标签内的内容忽略掉,其实也可以直接写成<span jwcid=”user”></span>,效果也是一样的,只不过加了User name后就方便了美工人员的排版设计。
4`#r E;h6h%e(A-atech.techweb.com.cnTechWeb-技术社区-H4c1L;Q:S8f1Z"`!N
请注意,HTML模板有它自己的命名规范,它的文件名应该与Page组件的定义文件相同,只不过是扩展名为.html,与普通的web服务器一般都有一个index.html类似,tapestry也有自己的”index.html”,只不过它的名字不是”index.html”,而是 Home.html,那么这些模板文件究竟应该放在哪儿呢?很简单,放在当前应用的目录下面就行了,比如我们的应用是Welcome,那把它放在 webapps/Welcome目录下面就行了。
6l1s#A5j Q,n"n%{#W$C.Gtech.techweb.com.cn/|(D9J5M:}'U%n0~%@3S
Home.page&J,?.^,L,M+s9L.b
4R%`!J+B;O Y;h0p5h%\5m$_程序开发,操作系统,服务器,源码下载,Linux,Unix,BSD,PHP,Apach,asp,下载,源码,黑客,安全,技术社区,技术论坛<?xml version="1.0" encoding="UTF-8"?>TechWeb-技术社区'p'z#U.]$l$T*L&[&b"v
<!DOCTYPE page-specification PUBLIC8z&g/}'N-V!m8Z
"-//Apache Software Foundation//Tapestry Specification 3.0//EN"tech.techweb.com.cn"Y5I2m4T2P&O1F*C-k
"http://jakarta.apache.org/tapestry/dtd/Tapestry_3_0.dtd">程序开发,操作系统,服务器,源码下载,Linux,Unix,BSD,PHP,Apach,asp,下载,源码,黑客,安全,技术社区,技术论坛!r5X;e$M;~(@#g
TechWeb-技术社区.j9R#d4j4F7T
<page-specification class="demo.Home">
.g!u.n)b1j0e<component id="user" type="Insert">.V*M8_:Y-x'D!S8P9T"H2S.D
<binding name="value" expression="userName"/>程序开发,操作系统,服务器,源码下载,Linux,Unix,BSD,PHP,Apach,asp,下载,源码,黑客,安全,技术社区,技术论坛$u#u.w.a$p4w!R#P-?,W
</component>%~8G;V;s9K6t
TechWeb-技术社区8a7h3n*{/]2f
<context-asset name="$template" path="Home.html"/>
%G;K7@#^.K J2d</page-specification>程序开发,操作系统,服务器,源码下载,Linux,Unix,BSD,PHP,Apach,asp,下载,源码,黑客,安全,技术社区,技术论坛&[%M-@8I!}
tech.techweb.com.cn&r0m7a-m-])o.s
以上这个文件便是这个名为”Home”的Page组件的页面定义文件,它好像是一座桥,联系着HTML模板和JAVA类进行协同工作。这个定义文件 “Home.page”实际上就是一个xml文件,它的根元素是page-specification,它有一个名为class的属性,用来指示HTML 模板与哪个java类协同工作,在本例中为demo.Home这个类。
|