45fan.com - 路饭网

搜索: 您的位置主页 > 电脑频道 > 电脑教程 > 阅读资讯:B/S开发框架介绍

B/S开发框架介绍

2016-09-04 16:15:06 来源:www.45fan.com 【

B/S开发框架介绍

下一代的B/S开发框架--Echo 教程(2)

原理

先看看Echo的效果:

比如在Echo的DEMO中, 我们点击"Disaplay Help"的复选框, 提示信息不见了, 但是整个页面却没有任何变化! 包括你选择的下拉列表和输入框中随意敲的文字, 一切状态都会被保留. 这种效果在桌面编程中很常见, 而HTML是无状态的, 一个提交后会刷新整个Frame. 一般的HTML实现这种效果有两个途径:

  1. 用隐藏的frame操作, 控制部目标域的Disaply属性. 通常要写很多的脚本.
  2. 提交到服务器上, 根据点击的按钮重写页面. 这样服务器上的JSP/XSLT/Servlet要写的很复杂, 需要保留上个页面提交的所有信息.

来看看Echo的观念:

  • 页面是服务器端控件的体现. 就象我们看到一个人, 不过是看到它身上反射的光线. 页面上的每个元件都是相应服务器端控件类的体现. 它们的状态, 内容和画出来的的样式, 都保存在控件中. Echo实际上是Servlet框架, 通常它要求程序返回一个类代表主窗口, 窗口里面又包含其它控件来代表页面上的输入框, 按钮, 表格等等. 这些控件和SWING的写法几乎一样. 我们知道Swing控件都会产生自己的Graph图形画在屏幕上. 而Echo控件在输出的时候, 它们会把自己的信息用HTML/JS写到输出, 构成你看到的页面.
  • 这些类存在哪里? Session. 所以即使你关掉窗口, 你还有机会从Session里面恢复它, 和原来一模一样.
  • 这么多类放倒Session里面会不会阴魂不散, 拖垮服务器? 有可能, 但是机会不大. Echo控件的确会占用不少内存, 但是在程序编写的时候通常我们会把不用的控件dispose()掉. 而且服务器上的Session会过期, 自然会丢掉里面的垃圾数据.

再来看看隐藏Help的实现:

  1. 编写页面的时候我们会注册复选框控件的ActionListner: 被点击后, 把Help区域的显示状态取反.
  2. 用户请求页面, 服务器端控件根据自己的状态输出HTML. 复选框控件在输出HTML时发现自己注册了Listener, 就自动输出一段脚本到HTML里面.
  3. 点击复选框后, 页面上的JS会用隐含Frame提交到服务器, 报告ECHO哪个页面上的哪个按钮被哪个家伙点击了, 同时还要提交页面上的所有输入.
  4. 服务器首从那个家伙的Session中找到对应的服务器端控件, 更新其状态, 然后会调用按钮的Listener程序, 对帮助区域显示状态取反.
  5. 处理完毕, 服务器回到步骤2, 客户端看到更新后的页面.

上面的步骤看起来也不简单. 别担心, 大多数工作是ECHO框架自动在处理, 而我们只是构造第一步中的页面和事件程序. 代码示例如下:

//可重用的帮助面板控件. 
public class HelpPanel extends Container implements ActionListener {
  //复选框
  private CheckBox visibilityCheckBox;
  private Grid.Cell descriptionCell; 

  public HelpPanel(String title, String description) {
    super();
    Grid grid = new Grid();
    grid.setBorderColor(new Color(0xafbfef));
...
...
    visibilityCheckBox = new CheckBox("Display Help", true);
//注册监听事件
    visibilityCheckBox.addActionListener(this);
...
...
  }
  //实现事件监听方法
  public void actionPerformed(ActionEvent e) {
//对帮助信息状态取反
    descriptionCell.setVisible(visibilityCheckBox.isSelected());
  }
}


 

本文地址:http://www.45fan.com/dnjc/72224.html
Tags: 开发 框架 下一代
编辑:路饭网
关于我们 | 联系我们 | 友情链接 | 网站地图 | Sitemap | App | 返回顶部