表单使用HTTP提交

表单有两种提交方式,第一种就是传统的HTTP提交。

最直接的步骤就是:

  • 使用FormPanel的setAction()方法,去定义submit的URL
  • 使用FormPanel的isValid()方法,去验证所有的fields是否有正确
  • 如果正确,使用FormPanel的submit()方法提交表单。
  1. setAction("http://www.example.com/submit.php");
  2. final Button btnSave = new Button("Save");
  3. btnSave.setIconStyle("save");
  4. btnSave.addSelectionListener(new SelectionListener<ButtonEvent>()
  5. {
  6. public void componentSelected(ButtonEvent ce) {
  7. if (isValid())
  8. {
  9. submit();
  10. } }
  11. });
  12. addButton(btnSave);
setAction("http://www.example.com/submit.php");
final Button btnSave = new Button("Save");
btnSave.setIconStyle("save");
btnSave.addSelectionListener(new SelectionListener<ButtonEvent>()
{
public void componentSelected(ButtonEvent ce) {
if (isValid())
{
submit();
} }
});
addButton(btnSave);

GWT RPC

表单就拥有了另外一种提交方式——RPC。对于GWT和GXT来说,他不像传统的web应用,在client端我们可以选择存储和操作java类型的数据——不管这些数据是在web前端还是通过GWT RPC或者JSON别的什么方法提交到后端,我们都可以操作他们。

在RSSReader项目里,我们就会使用GWT RPC。

创建一个Feed service

为了能够检索到Feed对象,就必须有唯一的ID。java里有专门用来生成的主键的类——UUID。接下来我们要实现一个功能,就是当在client端所使用Feed的实例对象,是通过RPC从server端返回的,并且已经赋值ID的。因为先前,我们所创建的Feed类,就是为了在client和server两端都可以使用。那么接下来就要创建一个GWT RPC的service去处理Feed实例对象。

  • 创建新包:com.danielvaughan.rssreader.client.services,在此包下,新建一个接口FeedService,继承GWT RemoteService。定义一个方法createNewFeed():
  1. package com.danielvaughan.rssreader.client.services;
  2. import com.danielvaughan.rssreader.shared.model.Feed;
  3. import com.google.gwt.user.client.rpc.RemoteService;
  4. import com.google.gwt.user.client.rpc.RemoteServiceRelativePath;
  5. @RemoteServiceRelativePath("feed-service")
  6. public interface FeedService extends RemoteService {
  7. Feed createNewFeed();
  8. }
package com.danielvaughan.rssreader.client.services;

import com.danielvaughan.rssreader.shared.model.Feed;
import com.google.gwt.user.client.rpc.RemoteService;
import com.google.gwt.user.client.rpc.RemoteServiceRelativePath; @RemoteServiceRelativePath("feed-service")
public interface FeedService extends RemoteService {
Feed createNewFeed();
}
  • 注意1:@RemoteServiceRelativePath("feed-service") 注解了当前这个service,在web.xml应该配置的url映射地址。也就是说不管哪个类实现了FeedService接口,那么他在web.xml的servlet url映射就应该设置成"feed-service"。
  • 注意2:FeedService接口创建完毕之后,GWT就会自动的提示你去创建与之对应的另外一个接口FeedServiceAsync

  1. package com.danielvaughan.rssreader.client.services;
  2. import com.danielvaughan.rssreader.shared.model.Feed;
  3. import com.google.gwt.user.client.rpc.AsyncCallback;
  4. public interface FeedServiceAsync {
  5. void createNewFeed(AsyncCallback<Feed> callback);
  6. }
package com.danielvaughan.rssreader.client.services;

import com.danielvaughan.rssreader.shared.model.Feed;
import com.google.gwt.user.client.rpc.AsyncCallback; public interface FeedServiceAsync { void createNewFeed(AsyncCallback<Feed> callback); }
  • FeedServiceAsync接口中生成了FeedService接口中的,异步回调的抽象方法。其目的是在createNewFeed()方法执行之后的返回期间会调用FeedServiceAsync接口中的与之对应的createNewFeed(AsyncCallback<Feed> callback)方法,来作为createNewFeed()方法执行情况的反馈。
  • 之前的两个接口都是属于client端的services,具体的实现类就应该属于的server端的services。所以新建包:com.danielvaughan.rssreader.server.services,在此包下创建FeedServiceImpl类实现FeedService,继承RemoteServiceServlet。具体的实现如下代码:
  1. package com.danielvaughan.rssreader.server.services;
  2. import java.io.IOException;
  3. import java.util.UUID;
  4. import com.danielvaughan.rssreader.client.services.FeedService;
  5. import com.danielvaughan.rssreader.shared.model.Feed;
  6. import com.google.gwt.user.server.rpc.RemoteServiceServlet;
  7. @SuppressWarnings("serial")
  8. public class FeedServiceImpl extends RemoteServiceServlet implements
  9. FeedService {
  10. @Override
  11. public Feed createNewFeed() {
  12. UUID uuid = UUID.randomUUID();
  13. return new Feed(uuid.toString());
  14. }
  15. }
package com.danielvaughan.rssreader.server.services;

import java.io.IOException;
import java.util.UUID; import com.danielvaughan.rssreader.client.services.FeedService;
import com.danielvaughan.rssreader.shared.model.Feed;
import com.google.gwt.user.server.rpc.RemoteServiceServlet; @SuppressWarnings("serial")
public class FeedServiceImpl extends RemoteServiceServlet implements
FeedService {
@Override
public Feed createNewFeed() {
UUID uuid = UUID.randomUUID();
return new Feed(uuid.toString());
} }
  • 配置FeedServiceImpl的servlet映射。编辑web.xml
  1. <servlet>
  2. <servlet-name>feedServlet</servlet-name>
  3. <servlet-class>
  4. com.danielvaughan.rssreader.server.services.FeedServiceImpl
  5. </servlet-class>
  6. </servlet>
  7. <servlet-mapping>
  8. <servlet-name>feedServlet</servlet-name>
  9. <url-pattern>/rssreader/feed-service</url-pattern>
  10. </servlet-mapping>
<servlet>
<servlet-name>feedServlet</servlet-name>
<servlet-class>
com.danielvaughan.rssreader.server.services.FeedServiceImpl
</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>feedServlet</servlet-name>
<url-pattern>/rssreader/feed-service</url-pattern>
</servlet-mapping>
  • 注意:<url-pattern>/rssreader/feed-service</url-pattern>其中的rssreader是小写,这与<script type="text/javascript" language="javascript"
        src="rssreader/rssreader.nocache.js"></script>是一直的。
  • RPC的services已经创建完毕了。只要记住他包括client端和server端代码。client端是接口的定义,server端是具体的实现。web.xml里配置的server端的servlet。

GXT之旅:第三章:表单和窗口(4)——表单的提交和RPC的更多相关文章

  1. Python之旅.第三章.函数4.01/4.02

    一.三元表达式 #普通的判断大小函数def max2(x,y): if x > y: return x else: return yres=max2(10,11)print(res)x=12y= ...

  2. Python之旅.第三章.函数3.30

    一.迭代器 1.什么是迭代?:迭代是一个重复的过程,并且每次重复都是基于上一次的结果而来2.要想了解迭代器到底是什么?必须先了解一个概念,即什么是可迭代的对象?可迭代的对象:在python中,但凡内置 ...

  3. Python之旅.第三章.函数3.29

    一.无参装饰器 1 开放封闭原则 软件一旦上线后,就应该遵循开放封闭原则,即对修改源代码是封闭的,对功能的扩展是开放的 也就是说我们必须找到一种解决方案: 能够在不修改一个功能源代码以及调用方式的前提 ...

  4. Python之旅.第三章.函数3.28

    一.命名关键字参数: 什么是命名关键字参数?格式:在*后面参数都是命名关键字参数特点:1 必须被传值1 约束函数的调用者必须按照key=value的形式传值2 约束函数的调用者必须用我们指定的key名 ...

  5. Python之旅.第三章.函数3.27

    一.形参与实参 1.形参与实参是什么? 形参(形式参数):指的是 在定义函数时,括号内定义的参数,形参其实就变量名 实参(实际参数),指的是 在调用函数时,括号内传入的值,实参其实就变量的值 x,y是 ...

  6. Python之旅.第三章.函数3.26

    一.函数: 1.为什么要有函数?什么是函数? 1.组织结构不清晰,可读性差 2.代码冗余 3.管理维护的难度极大,扩展性 具备某一个功能的工具就是程序的中函数 事先准备工具的过程---->函数的 ...

  7. Getting Started with Processing 第二,三章总结

    第一章是文化熏陶. 第二章:开始编程 菜单栏中的 Show 的快捷键 Run:进行显示shortcut:可以通过快捷键 cmd + R 执行Present:进行全屏的显示shortcut:可以通过按下 ...

  8. HTML第三章:表单

    第三章:表单 表单标签form:<form></form>//相当于一张记录用户信息的单子    常用属性:method:表单的提交方式,常用的值有两个             ...

  9. 第三章:Web表单

    感谢作者 –> 原文链接 本文翻译自 The Flask Mega-Tutorial Part III: Web Forms 这是Flask Mega-Tutorial系列的第三部分,我将告诉你 ...

随机推荐

  1. Qt之json解析

    Jsoner::Jsoner(QObject *parent) : QObject(parent){    QJsonObject json;    json.insert("loginna ...

  2. windows server 2008 R2 忘记administrator密码

    第一步: 插入安装光盘,重光驱启动系统,在选择“安装语言”的地方,按shift+F10 在弹出的CMD窗口中,输入以下地址: x:\>c: c:\>cd windows\system32 ...

  3. shell编程的一些例子5

    1.here文档 here文档允许我们调用一个交互式程序:可以从脚本程序中输出大量的文本,从而不必echo每行 例子1: #!/bin/bash cat<<!DATA! This is a ...

  4. SORT_AREA_RETAINED_SIZE

    manual pga: SORT_AREA_RETAINED_SIZE specifies (in bytes) the maximum amount of the user global area ...

  5. ARM编译器4字节对齐

    (1)我们假设只有一个赋初值的char型全局变量,那么系统会在data区分配一个4字节的存储空间来存储它.实际上,只用了1个字节,但是为了4字节对齐,只好分配4个字节,所以就会有3个字节浪费. (2) ...

  6. 工作流(worfflow)

    -- 工作流(Workflow)就是“业务过程的部分或整体在计算机应用环境下的自动化”,它主要解决的是“使在多个参与者之间按照某种预定义的规则传递文档.信息或任务的过程自动进行,从而实现某个预期的业务 ...

  7. eclipse开发android程序常见问题解决办法

    1:R.java不自动更新或不见,gen文件夹里没生成文件. 解决办法: 这个一般是xml文件中有错误,如有英文大写,属性值错误等,解决了就会好. 如果错都排除了还没有生成或更新,那么可以点击proj ...

  8. shell脚本学习积累笔记(第一篇)

    (1)首先,今天在执行shell脚本./test.sh时抛出“/bin/sh^M: bad interpreter: No such file or directory”的异常,百度后,才知道这是由于 ...

  9. 运行avalon.define()发生的事情

      avalon.define = function(id, factory) { var $id = id.$id || id if (!$id) { log("warning: vm必须 ...

  10. eclipse安装CDT插件遇到的问题

    转自eclipse安装CDT插件遇到的问题 已经安装了集成java版本的eclipse,eclipse-java-indigo-SR1-win32.zip,在添加CDT插件时,遇到了问题. cdt-m ...