`
dudo
  • 浏览: 21175 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
最近访客 更多访客>>
社区版块
存档分类
最新评论

新一代的Web表现层开发方法(欢迎讨论)

    博客分类:
  • JAVA
阅读更多

    目前基于javaweb开发框架数不胜数,而且其核心的功能都集中在web表现层的开发上,在这里我不打算对这些框架进行详细的分析和评论(因为针对这些框架的评论文章已经很多了),而是从另外一个角度提出一个新的Web表现层开发方法。

Web开发的大都有这样的体会,页面与逻辑总是纠缠不清,没有一个清楚地界限。有一些开发方法虽然可以将程序逻辑与网页分离开来,但是却带来的另外的复杂性,不是需要借助特定的tag,就是需要创建附加的模板文件,目前还没有一种框架(我所见到的,也许已经有了),能够真正实现页面与程序逻辑的完全分类,只是将这种关系转移了而已。

我所要描述的这种新的Web表现层开发方法的灵感来自于ORM技术。对象/关系映射技术将java对象映射至数据库,由ORM框架自动完成数据的crud操作。同样的,我们也可以将java对象映射至html文档,由框架来完成html文档的填充,开发人员只需要操作普通的java对象,即可实现以前由脚本或者模版完成的工作。我将这种技术称为odm(对象/文档映射)。之所以称之为odm而不是ohm(对象/html映射),是因为这种技术还可以应用于更广泛的场景,比如,java对象到xml的映射,到wml的映射等。大家可能会认为这并不是真正的新的技术,其实很多使用taglib和模版的框架中都在使用这样的方法。但是我所要描述的方法与这些方法在实现上很大的不同,主要在以下几个方面:

1 Java对象属性与html文档中的节点通过java对象属性名和html中节点的ID属性对应.

  使用这种方法保证了这种新的web开发方法不需要创建额外的模版,也不需要定义特定的taglib,最为主要的是将java对象,javascript脚本,css这几方统一命名,使得web开发的这几方面实现有机的统一,也使得这3个方面的相互操作成为可能。

2 程序开发人员所操作的只有java对象,没有任何的关于显示的循环、判断逻辑等。 

3 开发人员与美工完全可以独立的、并行的工作,不会出现垮领域操作。

<o:p> </o:p>关于如何将java对象属性影射到html文档节点,这里面有一套完整但却不需要特别记忆的映射规则,以后再写。

这个框架完成后将具有以下主要特性:

1 基于POJO

2 事件驱动;

3 原生的AJAX;

4 容易与现有的基于POJO的持久化框架集成,且更方便。

5 真正的所见即所得的页面开发

6 搜索引擎友好

7 无需复杂的配置文件,甚至不需要配置文件即可工作;

8 支持组件式开发;

9 真正的代码与页面分离。

……

还有更多的特性,比如可以将java属性映射到cooki,或者session变量甚至application级变量等,可以最大限对的简化web开发中的方方面面,可以说这个框架在开发效率以及可维护性方面将超越目前的其他所有的框架(有点说大了~_~)

   系统中一个html页面,对应一个页面类,它们通过一个约定来对应,不需要配置。

整个系统的模型有点像Delphi,熟悉delphi的朋友可能比较熟悉,在开发delphi GUI程序时,一个窗口对应一个dfm文件,而代码则放在pas文件中,dfm文件中的内容描述了窗口的gui组件的位置、颜色等显示信息,pas文件中则是事件处理代码。在webpilot中,html页面文件相当于delphi中的dfm文件,页面java类相当于delphi中的pas文件,页面java类中的事件处理函数相当于delphipas文件中的事件处理过程。

    

今天就写这么多了,写的比较零散,请大家见谅。这个方法我已经考虑了两年多了,已经有一个完整的实现思路,也已经有一个可运行的实现。工作一直比较忙,工作也与java不沾边,而且发现现在变懒了(^_^)。不过我还是希望能够实现一个真正可用东西。

文笔不好,有些地方可能说的不太清楚,请原谅。有什么疑问请提出,欢迎大家讨论。

分享到:
评论
23 楼 giscat 2007-01-22  
表现层真是越来越重要了,
以前一直搞服务器端,对客户端的东西不屑一顾,
现在大有长进,有时还能够帮美工MM做做美工,
N多难缠问题拿到客户端处理,相当之简洁完美方便
22 楼 SteveGY 2007-01-21  
<br/>
<strong>dudo 写道:</strong><br/>
<div class='quote_div'><font>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt;'><font size='3'><span style=''>    目前基于</span><span lang='EN-US'><font>java</font></span><span style=''>的</span><span lang='EN-US'><font>web</font></span><span style=''>开发框架数不胜数,而且其核心的功能都集中在</span><span lang='EN-US'><font>web</font></span><span style=''>表现层的开发上,在这里我不打算对这些框架进行详细的分析和评论</span><span lang='EN-US'><font>(</font></span><span style=''>因为针对这些框架的评论文章已经很多了</span><span lang='EN-US'><font>)</font></span><span style=''>,而是从另外一个角度提出一个新的</span><span lang='EN-US'><font>Web</font></span><span style=''>表现层开发方法。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt;'><font size='3'><span style=''/></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span style=''>作</span><span lang='EN-US'><font>Web</font></span><span style=''>开发的大都有这样的体会,页面与逻辑总是纠缠不清,没有一个清楚地界限。有一些开发方法虽然可以将程序逻辑与网页分离开来,但是却带来的另外的复杂性,不是需要借助特定的</span><span lang='EN-US'><font>tag,</font></span><span style=''>就是需要创建附加的模板文件,目前还没有一种框架</span><span lang='EN-US'><font>(</font></span><span style=''>我所见到的,也许已经有了</span><span lang='EN-US'><font>)</font></span><span style=''>,能够真正实现页面与程序逻辑的完全分类,只是将这种关系转移了而已。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span style=''/></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span style=''>我所要描述的这种新的</span><span lang='EN-US'><font>Web</font></span><span style=''>表现层开发方法的灵感来自于</span><span lang='EN-US'><font>ORM</font></span><span style=''>技术。对象</span><span lang='EN-US'><font>/</font></span><span style=''>关系映射技术将</span><span lang='EN-US'><font>java</font></span><span style=''>对象映射至数据库,由</span><span lang='EN-US'><font>ORM</font></span><span style=''>框架自动完成数据的</span><span lang='EN-US'><font>crud</font></span><span style=''>操作。同样的,我们也可以将</span><span lang='EN-US'><font>java</font></span><span style=''>对象映射至</span><span lang='EN-US'><font>html</font></span><span style=''>文档,由框架来完成</span><span lang='EN-US'><font>html</font></span><span style=''>文档的填充,开发人员只需要操作普通的</span><span lang='EN-US'><font>java</font></span><span style=''>对象,即可实现以前由脚本或者模版完成的工作。我将这种技术称为</span><span lang='EN-US'><font>odm(</font></span><span style=''>对象</span><span lang='EN-US'><font>/</font></span><span style=''>文档映射</span><span lang='EN-US'><font>)</font></span><span style=''>。之所以称之为</span><span lang='EN-US'><font>odm</font></span><span style=''>而不是</span><span lang='EN-US'><font>ohm(</font></span><span style=''>对象</span><span lang='EN-US'><font>/html</font></span><span style=''>映射</span><span lang='EN-US'><font>)</font></span><span style=''>,是因为这种技术还可以应用于更广泛的场景,比如</span><span lang='EN-US'><font>,java</font></span><span style=''>对象到</span><span lang='EN-US'><font>xml</font></span><span style=''>的映射,到</span><span lang='EN-US'><font>wml</font></span><span style=''>的映射等。大家可能会认为这并不是真正的新的技术,其实很多使用</span><span lang='EN-US'><font>taglib</font></span><span style=''>和模版的框架中都在使用这样的方法。但是我所要描述的方法与这些方法在实现上很大的不同,主要在以下几个方面:</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span style=''/></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 32.25pt; text-indent: -10.5pt;'><font size='3'><span lang='EN-US'><font>1 Java</font></span><span style=''>对象属性与</span><span lang='EN-US'><font>html</font></span><span style=''>文档中的节点通过</span><span lang='EN-US'><font>java</font></span><span style=''>对象属性名和</span><span lang='EN-US'><font>html</font></span><span style=''>中节点的</span><span lang='EN-US'><font>ID</font></span><span style=''>属性对应</span><span lang='EN-US'><font>.</font></span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 32.25pt; text-indent: -10.5pt;'><font size='3'><span lang='EN-US'><span style=''><font>  </font></span></span><span style=''>使用这种方法保证了这种新的</span><span lang='EN-US'><font>web</font></span><span style=''>开发方法不需要创建额外的模版,也不需要定义特定的</span><span lang='EN-US'><font>taglib</font></span><span style=''>,最为主要的是将</span><span lang='EN-US'><font>java</font></span><span style=''>对象</span><span lang='EN-US'><font>,javascript</font></span><span style=''>脚本,</span><span lang='EN-US'><font>css</font></span><span style=''>这几方统一命名,使得</span><span lang='EN-US'><font>web</font></span><span style=''>开发的这几方面实现有机的统一,也使得这</span><span lang='EN-US'><font>3</font></span><span style=''>个方面的相互操作成为可能。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><span lang='EN-US'><span style=''><font size='3'/></span></span></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 32.25pt; text-indent: -10.5pt;'><font size='3'><span lang='EN-US'><font>2 </font></span><span style=''>程序开发人员所操作的只有</span><span lang='EN-US'><font>java</font></span><span style=''>对象,没有任何的关于显示的循环、判断逻辑等。</span></font><span lang='EN-US'><span style=''><font size='3'> </font></span></span></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>3 </font></span><span style=''>开发人员与美工完全可以独立的、并行的工作,不会出现垮领域操作。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><span lang='EN-US'>&lt;o:p&gt;<font size='3'> </font>&lt;/o:p&gt;</span><font size='3'><span style=''>关于如何将</span><span lang='EN-US'><font>java</font></span><span style=''>对象属性影射到</span><span lang='EN-US'><font>html</font></span><span style=''>文档节点,这里面有一套完整但却不需要特别记忆的映射规则,以后再写。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 0.75pt;'><span style=''><font size='3'>这个框架完成后将具有以下主要特性:</font></span></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 0.75pt;'><span style=''><font size='3'/></span></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>1 </font></span><span style=''>基于</span><span lang='EN-US'><font>POJO</font></span><span style=''>;</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>2 </font></span><span style=''>事件驱动;</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>3 </font></span><span style=''>原生的</span><span lang='EN-US'><font>AJAX;</font></span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>4 </font></span><span style=''>容易与现有的基于</span><span lang='EN-US'><font>POJO</font></span><span style=''>的持久化框架集成,且更方便。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>5 </font></span><span style=''>真正的所见即所得的页面开发</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>6 </font></span><span style=''>搜索引擎友好</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>7 </font></span><span style=''>无需复杂的配置文件,甚至不需要配置文件即可工作;</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>8 </font></span><span style=''>支持组件式开发;</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span lang='EN-US'><font>9 </font></span><span style=''>真正的代码与页面分离。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><span lang='EN-US'><font size='3'>……</font></span></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><span lang='EN-US'><font size='3'/></span></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span style=''>还有更多的特性,比如可以将</span><span lang='EN-US'><font>java</font></span><span style=''>属性映射到</span><span lang='EN-US'><font>cooki,</font></span><span style=''>或者</span><span lang='EN-US'><font>session</font></span><span style=''>变量甚至</span><span lang='EN-US'><font>application</font></span><span style=''>级变量等,可以最大限对的简化</span><span lang='EN-US'><font>web</font></span><span style=''>开发中的方方面面,可以说这个框架在开发效率以及可维护性方面将超越目前的其他所有的框架</span><span lang='EN-US'><font>(</font></span><span style=''>有点说大了</span><span lang='EN-US'><font>~_~)</font></span><span style=''>。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt; text-indent: 21.75pt;'><font size='3'><span style=''/></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 21pt; text-indent: 0.75pt;'><font size='3'><span lang='EN-US'><span style=''><font>   </font></span></span><span style=''>系统中一个</span><span lang='EN-US'><font>html</font></span><span style=''>页面,对应一个页面类,它们通过一个约定来对应,不需要配置。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 21pt; text-indent: 21.75pt;'><font size='3'><span style=''>整个系统的模型有点像</span><span lang='EN-US'><font>Delphi</font></span><span style=''>,熟悉</span><span lang='EN-US'><font>delphi</font></span><span style=''>的朋友可能比较熟悉,在开发</span><span lang='EN-US'><font>delphi GUI</font></span><span style=''>程序时,一个窗口对应一个</span><span lang='EN-US'><font>dfm</font></span><span style=''>文件</span><span lang='EN-US'><font>,</font></span><span style=''>而代码则放在</span><span lang='EN-US'><font>pas</font></span><span style=''>文件中,</span><span lang='EN-US'><font>dfm</font></span><span style=''>文件中的内容描述了窗口的</span><span lang='EN-US'><font>gui</font></span><span style=''>组件的位置、颜色等显示信息,</span><span lang='EN-US'><font>pas</font></span><span style=''>文件中则是事件处理代码。在</span><span lang='EN-US'><font>webpilot</font></span><span style=''>中,</span><span lang='EN-US'><font>html</font></span><span style=''>页面文件相当于</span><span lang='EN-US'><font>delphi</font></span><span style=''>中的</span><span lang='EN-US'><font>dfm</font></span><span style=''>文件,页面</span><span lang='EN-US'><font>java</font></span><span style=''>类相当于</span><span lang='EN-US'><font>delphi</font></span><span style=''>中的</span><span lang='EN-US'><font>pas</font></span><span style=''>文件,页面</span><span lang='EN-US'><font>java</font></span><span style=''>类中的事件处理函数相当于</span><span lang='EN-US'><font>delphi</font></span><span style=''>中</span><span lang='EN-US'><font>pas</font></span><span style=''>文件中的事件处理过程。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 21pt; text-indent: 0.75pt;'><span lang='EN-US'><span style=''><font size='3'>     </font></span></span></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 21pt; text-indent: 0.75pt;'><font size='3'><span style=''>今天就写这么多了,写的比较零散,请大家见谅。这个方法我已经考虑了两年多了,已经有一个完整的实现思路,也已经有一个可运行的实现。工作一直比较忙,工作也与</span><span lang='EN-US'><font>java</font></span><span style=''>不沾边,而且发现现在变懒了</span><span lang='EN-US'><font>(^_^)</font></span><span style=''>。不过我还是希望能够实现一个真正可用东西。</span></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 21pt; text-indent: 0.75pt;'><font size='3'><span style=''/></font></p>
<p class='MsoNormal' style='margin: 0cm 0cm 0pt 21pt; text-indent: 11.25pt;'><span style=''><font size='3'>文笔不好,有些地方可能说的不太清楚,请原谅。有什么疑问请提出,欢迎大家讨论。</font></span></p>
</font></div>
<br/>
<br/>
<br/>
<br/>
<div style='margin: 0cm 0cm 0pt 21pt; text-indent: 0.75pt;'><strong>“词汇疲劳”。</strong>楼主已经写了一堆似是而非的东西,唯一看的出来的是,楼主曾经是delphi的开发人员,并且试图以过去的经验来解决java web开发过程中遇到的一些问题。有这样的想法也无可非议,但,目前世界上真正实现了这一堆功能的,只有ASP.NET,在具有强大的IDE的支持下,这样的一种implementation才可以称为是effective的。甚至JSF,离这一目标还有很遥远的距离。</div>
<div style='margin: 0cm 0cm 0pt 21pt; text-indent: 0.75pt;'>我不常来这里,我也没有评分的爱好,不过要是我可以评分的话,我投票是“新手帖”</div>
21 楼 JavaInActoin 2007-01-18  
楼主看一下JSF吧,不要瞎忙乎了
20 楼 qy33 2007-01-18  
studying...
19 楼 过河卒 2007-01-18  
期待实际的例子!学习中。。
18 楼 dudo 2007-01-18  
比wicket的开发更简单,目前看到的只有Tapestry 5有点类似,但是比Tapestry 5将更简单。


  这几天比较忙,本来要放一个例子上来,一回到家就忘记了,今天晚上贴一个例子,能更明白些。
17 楼 wxwdt 2007-01-18  
就是wicket就是这种思想!!!
16 楼 flyingbug 2007-01-17  
楼主说的是wicket吧?
15 楼 amozon 2007-01-17  
感觉楼主想做的和zk有相似之处
14 楼 dudo 2007-01-17  
billyu 写道
看了下,其实这个思想就是xmlc的思想封装吧,http://www.enhydra.org/ 实现的很好啊,只是用起来还是有些问题的。

忘了贴一个地址:

可以参看这个比较老一点的文章

http://www-128.ibm.com/developerworks/cn/linux/l-enhydra/index.html



完全不一样,不需要生成dom树,效率会高很多,而且更直观,就像操作持久类一样。
13 楼 billyu 2007-01-17  
看了下,其实这个思想就是xmlc的思想封装吧,http://www.enhydra.org/ 实现的很好啊,只是用起来还是有些问题的。

忘了贴一个地址:

可以参看这个比较老一点的文章

http://www-128.ibm.com/developerworks/cn/linux/l-enhydra/index.html

12 楼 giscat 2007-01-17  
表现层跑完龙套,果然要唱主角了,
11 楼 dudo 2007-01-17  
<br/>
<strong>AllenYoung 写道:</strong><br/>
<div class='quote_div'>你说的这个我怎么感觉和基于组件编程有些象呢?比如普元EOS这样的东西,就是把一个对象实体映射到数据库、xml还有网页,只不过它用的是source code生成,而你现在用别的?<br/>
<br/>
我觉得所有现在所谓的新开发方法,比如GWT,当然还有你提出的这个模型,都有一个问题,就是如何与现有的技术集成。你说所有的东东(除了美工)都在Java中写,那我要用一些第三方的Ajax库怎么办?比如我要用dhtmlXGrid和DWR,怎么办呢?当然,如果你足够牛,能在你的框架内提供所有第三方类库的替代品或以Java为表现形式的整合方式,那倒是可以考虑使用你的模型。<br/>
<br/>
其实我一直在关注GWT类似的东西,很多人都说它好,从编程模型上看确实也挺新鲜的,但是我怎么把它和其他类库一起使用呢?这个是所有新编程模型都要面对的问题。<br/>
<br/>
另外,还有一个恶心的遗留代码问题。你的新模型只能用来开发新程序,不能用来改善遗留系统,除非你提供一个从HTML到Java的转换工具(或类似的机制)。当然,用恶心的遗留代码来刁难新模型,本身就不是太应该的,哈哈。</div>
<p><br/>
<br/>
to <strong>AllenYoung:</strong></p>
<p>1 我所讲的框架可以基于组件编程,但并不止局限于组建编程;</p>
<p>2 这个框架与其他技术的集成,自然会留有接口。目前需要集成的只是第三方的Ajax库,有于这个框架只是一个web表现层的开发框架,所以后台业务处理使用什么技术,使用者完全可以自己处理。当然为了使更加方便还是要提供一些措施来处理这些问题。</p>
<p>3 遗留代码的改造问题历来都是一个头疼的问题,并不能一概而论那个框架不能改造遗留系统。由于这个框架只是一个web表现层的开发框架,所以只要以前的系统是分层开发,改造起来都不回太复杂。</p>
<p>下面我会给出一个简单的例子作一个示例.</p>
<p> </p>
10 楼 歆渊 2007-01-16  
galaxystar 写道
Book/byISBN/13-978-0201485677
这种方式也有一个缺陷,该参数key必须是双方协定好的!

key是指哪一部分?
用参数的话就不需要协定了么?
9 楼 galaxystar 2007-01-16  
Book/byISBN/13-978-0201485677
这种方式也有一个缺陷,该参数key必须是双方协定好的!
8 楼 歆渊 2007-01-16  
如果遗留系统都只能保留, 不知道现在还有多少人在写 COBOL ...

BTW. JE = JavaEye
7 楼 AllenYoung 2007-01-16  
你说的这个我怎么感觉和基于组件编程有些象呢?比如普元EOS这样的东西,就是把一个对象实体映射到数据库、xml还有网页,只不过它用的是source code生成,而你现在用别的?<br/>
<br/>
我觉得所有现在所谓的新开发方法,比如GWT,当然还有你提出的这个模型,都有一个问题,就是如何与现有的技术集成。你说所有的东东(除了美工)都在Java中写,那我要用一些第三方的Ajax库怎么办?比如我要用dhtmlXGrid和DWR,怎么办呢?当然,如果你足够牛,能在你的框架内提供所有第三方类库的替代品或以Java为表现形式的整合方式,那倒是可以考虑使用你的模型。<br/>
<br/>
其实我一直在关注GWT类似的东西,很多人都说它好,从编程模型上看确实也挺新鲜的,但是我怎么把它和其他类库一起使用呢?这个是所有新编程模型都要面对的问题。<br/>
<br/>
另外,还有一个恶心的遗留代码问题。你的新模型只能用来开发新程序,不能用来改善遗留系统,除非你提供一个从HTML到Java的转换工具(或类似的机制)。当然,用恶心的遗留代码来刁难新模型,本身就不是太应该的,哈哈。
6 楼 AllenYoung 2007-01-16  
complystill 写道
好像现在的JE就是类似的形式, 不知道是RoR的传统还是JE自创, 反正觉得这样会比Servlet传统的模式要好.

楼主说已经有可以实现的例子了, 希望能贴一些简单直观的片段出来看看.


JE是啥...就这么两个字母,google都难...
5 楼 歆渊 2007-01-16  
我很少写Web页面, 不过在 URL 映射方面有些可能和楼主类似的想法, 比如用
/Book/byISBN/13-978-0201485677

代替
/showProducts.do?class=Book&qn=ISBN&qv=13-978-0201485677


/TShirt/bySize/XL

代替
/showProducts.do?class=TShirt&qn=size&qv=XL


这样就可以直接映射到处理类的方法上, 比如:
public class Product implements WebModel
{
  public WebModel create(Env env, WebPath path, WebParams params)
  {
     String type = path.head();
     return env.getFactory().create(type, params);
  }
}

public class Book extends Product
{
  public WebModel byISBN(Env env, WebPath path, WebParams params)
  {
     List<Book> books = env.getDAO().query(this.getClass(), 
                        "ISBN = ?", Integer.parseInt(path.head()));
     return books.size() > 0 ? books.iterator().next() : null;
  }
}

public class TShirt extends Product
{
  public WebModel bySize(Env env, WebPath path, WebParams params)
  {
     List<TShirt> shirts = env.getDAO().query(this.getClass(), 
                           "size = ?", path.head());
     return books.size() > 0 ? shirts.iterator().next() : null;
  }
}



好像现在的JE(JavaEye)就是类似的形式, 不知道是RoR的传统还是JE自创, 反正觉得这样会比Servlet传统的模式要好.


楼主说已经有可以实现的例子了, 希望能贴一些简单直观的片段出来看看.
4 楼 lighter 2007-01-16  
对于一大堆的理论通常不感兴趣,我最喜欢看到实例,源代码后,再去看一下别人说得理论是否确实如此....

相关推荐

    下一代Web前端技术

    本文将深入探讨下一代Web前端技术的核心知识点,包括用户体验优化、网络通信改进以及混合应用开发等方面。 #### 二、用户体验优化 1. **加载速度优化**:提高页面加载速度是用户体验优化的重要方面之一。根据Jakob...

    HTML5移动Web开发指南

    HTML5是新一代的HTML标准,它是互联网发展的重要里程碑。HTML5不仅提升了Web的表现力和功能性,更是引入了大量新的API和元素,这为开发富互联网应用(Rich Internet Applications, RIA)提供了可能。在移动Web开发中...

    Java Web服务开发

    内容简介:本书全面深入地探讨了下一代分布式计算技术—— Web服务,深入透彻地阐述了如何使用Java实现和部署Web服务,同时也全面介绍了与之相关的基础知识。在详细介绍了Web服务之后,本书还引导您探讨Web服务体系...

    新一代VisualBasic2005程序设计光盘

    《新一代VisualBasic2005程序设计》是针对编程初学者和进阶者的一套教程,旨在介绍微软的VisualBasic2005编程环境及其应用。这个光盘内容分为多个章节,通过不同的压缩子文件来分块提供。下面将详细阐述每个章节的...

    JavaScript Web Application

    《JavaScript Web 富应用开发》一书详细介绍了如何利用现代 Web 技术构建下一代互联网富应用程序。随着 MVC(Model-View-Controller)架构在前端领域的广泛应用和发展,该书应运而生。本书的作者 Alex MacCaw 是一位...

    新工科背景下Web前端课程教学改革.pdf

    新工科背景下,Web前端课程教学改革的目的是为了适应新时代对工程技术人才的需求,尤其是在创新驱动发展、"中国制造2025"、"互联网+"等战略推动下,培养具有扎实科学基础、强大工程实践能力和高综合素质的新一代工科...

    2018web前端开发值得关注的几个趋势.pdf

    总结:2018年的Web前端开发趋势表明,技术在不断进化,开发者需要不断学习新技术,如PWA、TypeScript和WebAssembly,同时关注新工具和框架,如Parcel和Yarn,以及优化用户体验的布局技术。此外,理解人工智能和...

    ASP.NET与Web Service实例剖析

    ASP.NET的新一代改进包括了更强的网页模型,支持编译式语言(如C#),具备层次性功能的架构,简化部署,增强性能和扩展性,以及解决Web Form中的Session问题。这一切都得益于微软的.NET Framework,其中包括Base ...

    英文版Head First Mobile Web

    书中还提到了对未来移动Web开发的展望,认为现在是探索移动Web开发的混乱世界(chaotic world),并讨论了如何以及应该怎样应对未来。《Head First Mobile Web》不仅仅是对当前知识的介绍,也对未来技术趋势提出了...

    目 录关键词本文是一篇讨论基于Web的数据库管理的本科毕业论文,它详细地讲述了开发一个基于Web的通用BBS(Bullitin Board Syste统所用到的技术和方法。其中运用了ASP技术(Avtive Server Page)、ADO技术(ActiveX Data Object)、MS Access数据库技术、RegExp技术(Regular Expression 正则表达式)、VBScript及JavaScript脚本语言技术等等,并从几个不同的方面来对上述技术的实现方法进行了讨论。

    传统的单机版应用软件正在逐渐退出舞台,取而代之的是支持网络、支持多种数据信息(多媒体)的新一代网络版应用软件,而目前网络版软件中似乎存在着两种不同的趋势,一种是称为客户端——服务器的C/S结构应用系统,...

    CSS3 For Web Designers

    他强调了CSS3作为新一代样式表语言,是如何推动网页设计进步的。本章中提到的一些关键知识点包括: - **CSS3的历史背景**:通过回顾CSS的发展史,读者可以了解到CSS3是在哪些关键转折点上被开发出来的,以及这些...

    (完整word版)假期web前端实习报告.doc

    HTML5是新一代的HTML标准,它支持多媒体内容、图形和实时通讯等新特性。CSS作为样式表语言,负责网页的样式和布局,使得Web页面的展示更加丰富和灵活。JavaScript则是一种运行在浏览器端的脚本语言,它为网页添加了...

    Web Servies Essentials.pdf

    本书深入浅出地介绍了新一代分布式服务的基础,并通过开源Java工具展示了快速创建服务的方法。此外,书中还详细探讨了四个关键新兴技术:XML-RPC、SOAP、UDDI 和 WSDL。 #### 书籍结构与内容概览 - **第一部分:...

    面向开发人员之ASP.NET开发技术系列课程(4):JSP开发人员篇——如何转向ASP.NET开发

    5. **Web Forms与ASP.NET Core对比**:虽然本课程可能主要关注传统的ASP.NET Web Forms,但也会提及ASP.NET Core,这是.NET的新一代跨平台框架,具有更高的性能和现代化的开发体验。 6. **转换策略**:对于从JSP...

    JsGen是用纯JavaScript编写的新一代开源社区网站系统

    **JsGen:JavaScript构建的新一代开源社区平台** JsGen是一个完全使用JavaScript编写的开源社区网站系统,它展示了JavaScript在Web开发中的强大潜力。这个系统设计的初衷是为了搭建社交网络服务(SNS)类型的社区,...

    Web前端实习报告-.docx

    - HTML5:新一代的HTML标准,具有语义化特性,增强了本地存储能力,提供了更好的图形处理和多媒体支持,以及增强表单控制等。 - CSS:用于控制网页样式,使得网页设计更加灵活和美观。 - JavaScript:客户端脚本...

    html5高级程序设计

    逐一讨论了HTML5的Canvas、Geolocation、Communication、WebSocket、Forms、Web Workers、Storage等APⅡ的使用,辅以直观明了的客户端和服务器端示例代码,让开发人员能够迅速理解和掌握新一代Web标准所涵盖的核心...

    android web高级应用编程随书代码

    讨论HTML5 的Canvas、Geolocation 、Communication、WebSocket、Forms、Web Workers、Storage 等API 的使用, 辅以直观明了的客户端和服务器端示例代码,让开发人员能够迅速理解和掌握新一代Web 标准所涵盖的核心...

Global site tag (gtag.js) - Google Analytics