`
wenqiang06ky
  • 浏览: 72065 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

深入浅出GWT(一)——基础篇之表单设计

阅读更多

前言
GXT只是GWT基础上的升级,所以这里所说的GWT包含了GXT,也就是升级版的GWT。
GWT的最小单位并不是表单,甚至有时候并不需要以表单为单位处理数据,但表单依然是GWT开发中不可或缺的一个单元,我们习惯性的将一个表单里的数据放在一起进行处理。例如图书管理里面新增一个书,我们习惯性的将这本书的所有信息放在一个表单里面,然后将这个表单里面的数据一次性保存下来。当然,由于需求的需要,你也可以在点击保存的时候或者在点击保存之前对这些数据分开进行处理。
总而言之,GWT处理数据并不依赖表单为单位,但这些数据的输入输出需要表单作为平台。
下面结合例子对各个基础组件一一进行描述。


一、前台处理技术之表单基础组件
(一) LabelField-->文字域

1、举例
LabelField titleLabel = new LabelField(“投票标题(限512字以内): ”);  

2、使用说明
相当于文字说明,常用于下列基础组件之前的文字描述。


(二)TextField-->文本框
1、举例:新增一个文本框,让用户输入投票的标题。代码如下:
TextField<String> ballotTitle = new TextField<String>();
ballotTitle.setWidth(215);
ballotTitle.setAllowBlank(false);
ballotTitle.setValue(ballotData.getBallot_title());
ballotTitle.getMessages().setBlankText(SID.LANG.ballot_BallotInfoAddDialog_BlankLimit());   
ballotTitle.setMaxLength(512);
ballotTitle.getMessages().setMaxLengthText(“投票标题最大长度为512字!”);
// ballotTitle.setRegex("^[1-9][0-9]*$");
// ballotTitle.getMessages().setRegexText("请正确输入正整数!");
// ballotTitle.setLabelStyle(IReadConstants.FORM_LABEL_BOLD_STYLE);
ballotTitle.setEnabled(true);
ballotTitle.setEditable(true);
ballotTitle.setReadOnly(false);

2、使用说明:
(1)用new TextField<String>()的方式生成一个文本框。
(2)setWidth(int width)-->设置文本框宽度。
(3)setAllowBlank(boolean allowBlank)-->设置是否可空。
(4)getMessages().setBlankText(String arg0)-->若文本框为空且setAllowBlank设置为true时的提示信息。
(5)setValue(String value)-->设置文本框的值。通常编辑的时候要用到。
(6)setMaxLength(int maxLength)-->设置文本框值的最大长度。
(7)getMessages().setMaxLengthText(Sring arg0)-->若超过设置的最大长度时的提示语。
(8)setRegex(String regex)-->设置正则表达式校验。
(9)getMessages().setRegexText(String arg0)-->若违反正则表达式时的提示语。
(10)setLabelStyle(String labelStyle)-->设置文字风格。常和setFieldLabel(String arg0)搭配使用,否则设置无效。
(11)setEnabled(boolean disabled)-->是否置灰。
(12)setEditable(boolean editabled)-->是否可编辑。
(13)setReadOnly(boolean)-->设置是否只读属性。
Note:以上最常用的属性值要视情况是否需要设置。



(三)DateField-->时间控件(yyyy-MM-dd)

1、举例:新增一个时间控件,让用户选择时间。代码如下:
DateField getBeginDate = new DateField();
// getBeginDate.setLabelStyle(IReadConstants.FORM_LABEL_BOLD_STYLE);
getBeginDate.setWidth(90);
getBeginDate.getPropertyEditor().setFormat(DateTimeFormat.getFormat("yyyy-MM-dd"));
getBeginDate.setEnabled(true);
getBeginDate.setAllowBlank(false);
getBeginDate.setEditable(false);
getBeginDate.setValue(ballotData.getStartDate());
getBeginDate.getMessages().setBlankText(SID.LANG.ballot_BallotInfoAddDialog_BlankLimit());

2、使用说明
(1)用new DateField()的方式生成一个时间控件
(2)getPropertyEditor().setFormat(DateTimeFormat format)-->设置日期控件的显示格式。
(3)其它用法请参TextField使用说明。
Note:若时间控件只能显示yyyy-MM-dd,那么需要时分秒时就要配合ComboBox组件使用(下面详细讲解)。



(四)TextArea-->文本域
1、举例:新增一个文本域,让用户输入文本内容。代码如下:
TextArea content = new TextArea();
content.setHeight(300);
content.setWidth(480);

2、使用说明
(1)当输入的内容较多时可以考虑用TextArea,用new TextArea()的方式生成一个文本域。
(2)setHeight(int height)-->设置文本框的高。
(3)setWidth(int width)-->设置文本框的宽。
(4)其它常见的属性设置请参TextField使用说明。



(五)ComboBox与ListStore-->下拉列表
1、举例:页面编辑系统/标签库管理/高级查询/页面类型下拉列表。代码如下:
// ListStore
ListStore<State> pageType = new ListStore<State>();
pageType.add(LableData.getPageTypeStates());

// ComboBox
ComboBox<State> pageTypeComboBox = new ComboBox<State>();
pageTypeComboBox.setEmptyText("---------请选择---------");
pageTypeComboBox.setEditable(false);
pageTypeComboBox.setDisplayField("name");
pageTypeComboBox.setValueField("id");
pageTypeComboBox.setWidth(150);
pageTypeComboBox.setStore(pageType);

// LableData.getPageTypeStates()
public static List<State> getPageTypeStates()
{
    List<State> states = new ArrayList<State>();
    states.add(new State("1", "创建页面"));
    states.add(new State("2", "引用页面"));
    return states;
}

2、使用说明:
(1)ListStore-->下拉列表的下拉菜单项。
(2)setDisplayField(String displayField)-->下拉菜单显示的值。
(3)setValueField(String valueField)-->下拉菜单实际的值。
(4)setEmptyText(String emptyText)-->设置下拉菜单的空文本项。
(5)setStore(ListStore<State> store)-->设置下拉列表的下拉菜单项。
Notes:
<1> setDisplayField与setValueField的值与State中的值对应。
<2> 比较常见的用法还有时分秒的下拉列表,不同的是编辑的时候要获取数据库中保存的值,所以它就要多设置一个属性,如设置小时的下拉列表:
// ListStore
ListStore<HourModel> hourList = new ListStore<HourModel>();
hourList.add(PageManageData.getHour());
// ComboBox
ComboBox<HourModel> hour = new ComboBox<HourModel>();
hour.setLabelStyle(IReadConstants.FORM_LABEL_BOLD_STYLE);
hour.setDisplayField("hour");
hour.setWidth(40);
hour.setMinListWidth(40);
hour.setStore(hourList);
hour.setEditable(false);
hour.setSelection(PageManageData.getHour());
// 新增的时候设置默认值,编辑的时候将0到9之间的值前面添加一个0
if (!isEmpty(ballotData.getHour()))
{
    hour.setValue(PageManageData.getHourModelByID(ballotData.getHour()));
               
    if (ballotData.getHour().length() == 1)
    {
        hour.setValue(PageManageData.getHourModelByID("0" + ballotData.getHour()));
    }
}
else
{
    hour.setValue(PageManageData.getHourModelByID("00"));
}



(六)RadioGroup与Radio-->单选框组件,Radio是单选框的选项单元
1、举例:新增一个单选框组件,拥有两个选项单元:是和否。代码如下:
Radio radio = new Radio();
radio.setBoxLabel("是");
           
Radio radio2 = new Radio();
radio2.setBoxLabel("否");
           
// 将radio加入到group中
RadioGroup radioGroup = new RadioGroup();
radioGroup.setFieldLabel("是否显示图片");
radioGroup.add(radio);
radioGroup.add(radio2);
radio.setName(name);
// radio.setValue(!value);
// radio2.setValue(value);
           
2、使用说明:
(1)Radio是单选框的选项单元,需要多少个选项就添加都少个Radio
(2)setBoxLabel(String boxLabel)-->设置选项单元的文字描述
(3)setFieldLabel(String fieldLabel-->设置单选框组件的文字描述
(4)add(Radio field)-->添加选项单元
(5)setName(String name)-->设置HTML的属性名,若只有两个选项只需要设置一个即可。
(6)setValue(Boolean value)-->在编辑数据的时候需要用到赋值



(七)CheckBoxGroup与CheckBox-->复选框,CheckBox是复选框的选项单元
1、举例:内容管理/新闻发布管理/新增/位置。代码如下:
CheckBoxGroup checkBoxGroup = new CheckBoxGroup();
checkBoxGroup.setFieldLabel("位置:");

CheckBox isTopCB = new CheckBox();
isTopCB.setId("0");
isTopCB.setBoxLabel("分类置顶");
// isTopCB.setValue(true);

CheckBox isInMainPageCB = new CheckBox();
isInMainPageCB.setId("1");
isInMainPageCB.setBoxLabel("首页显示");
// isInMainPageCB.setValue(true);

checkBoxGroup.add(isTopCB);
checkBoxGroup.add(isInMainPageCB);

2、使用说明:
(1)setFieldLabel(String fieldLabel)-->设置复选框的文字描述
(2)setId(String id)-->设置选项单元的id标识
(3)setBoxLabel(String boxLabel)-->设置选项单元的文字描述
Note:复选框的数据需要一些特殊处理,这个在下一篇总结《深入浅出GWT(二)--基础篇之表单数据处理》详细描述。

二、前台处理技术之表单基础布局
(一)HorizontalPanel-->水平面板
1、举例:
LabelField titleLabel = new LabelField("投票标题:");
TextField<String> ballotTitle = new TextField<String>();
HorizontalPanel titlePanel = new HorizontalPanel();
titlePanel.setSpacing(10);
titlePanel.setHorizontalAlign(HorizontalAlignment.LEFT);
titlePanel.add(titleLabel);
titlePanel.add(ballotTitle);

2、使用说明:
(1)setSpacing(int spacing)-->设置面板的空间。
(2)setHorizontalAlign(horizontalAlignment horizontalAlign)-->设置面板的位置。
(3)add(Widget widget)-->添加组件。添加的所有组件都是放在同一行的。


(二)VerticalPanel-->垂直面板
1、举例:
VerticalPanel vp = new VerticalPanel();
vp.setSpacing(10);
vp.add(titleLabel);

2、使用说明:
(1)setSpacing(int spacing)-->设置面板的空间。
(2)setHorizontalAlign(horizontalAlignment horizontalAlign)-->设置面板的位置。
(3)add(Widget widget)-->添加组件。添加的所有组件都是放在同一垂直面板的。
Note:水平面板和垂直面板之间可以任意嵌套。


(三)FieldSet-->域,即可以将基础组件都封装在域里面
1、举例:
FieldSet ballotOtherSet = new FieldSet();
ballotOtherSet.setHeading("投票标题(必填)、投票数(必填)设置");            
ballotOtherSet.setWidth(450);

// 域的布局
TableLayout otherLayout = new TableLayout();
otherLayout.setCellSpacing(10);
ballotOtherSet.setLayout(otherLayout);

ballotOtherSet.add(titlePanel);        // 投票标题
ballotOtherSet.add(perPanel);          // 每人每天可投票的选项项数
ballotOtherSet.add(totalPanel);        // 每个选项每人的总投票数
ballotOtherSet.add(optionLimitPanel);  // 每个选项每人每天的投票数

2、使用说明:
(1)setHeading(String heading)-->设置域的头
(2)setWidth(int width)-->设置域的宽
(3)setLayout(Layout layout)-->设置域的布局
(4)setCellSpacing(int cellSpacing)-->设置布局单元的空间
(5)add(Widget widget)-->添加组件到域里面

Note:FieldSet并不是非要不可,要视情况而定,可以将表单项类似的项放在一个域里面。这样显得简洁美观。


(四)FormPanel-->form表单
1、举例:
FormPanel form = createCommFormPanel(100);
form.setHeight(500);
form.add(ballotOtherSet);

2、使用说明:以上三种基础布局可以任意嵌套地添加到FormPanel里面,也可以直接添加基础组件,总之,设计出能让用户满意的表单界面是我们的宗旨。

(五)ContentPanel-->内容面板:页面布局的时候经常用到此面板。详见《深入浅出GWT(三)——基础篇之页面布局》
2
5
分享到:
评论
1 楼 wenqiang06ky 2010-06-09  
说明:关于GWT的总结后期还有至少4到5篇,
望有相同工作经验或者正在学习或研究此技术的同学们不吝赐教

相关推荐

    Gwt-ext学习笔记之基础篇

    ### Gwt-ext学习笔记之基础篇 #### 一、安装CypalStudio工具 为了能够开始Gwt-ext的学习之旅,首先需要确保开发环境已经搭建好。CypalStudio是一款非常实用的工具,它能帮助开发者更高效地进行GWT项目的开发。 1....

    Gwt-Ext学习笔记之基础篇- www.hxiaseo.cn技术网站

    标题中的"Gwt-Ext学习笔记之基础篇"指的是关于Gwt-Ext的初级教程,这是一种基于Google Web Toolkit (GWT) 的扩展库,用于构建富互联网应用程序(RIA)。Gwt-Ext提供了丰富的用户界面组件,使得开发者可以利用Java语言...

    GWT快速开发(GWT) 是一个Java软件开发框架用于开发类似于Google Maps和Gmail的AJAX应用程序。GWT的设计参考Java AWT包设计,类命名规则、接口设计、事件监听等。你可以用Java编程语言开发你的界面,然后用GWT编译器将Java类转换成适合浏览器执行的...

    ### GWT快速开发知识点详解 #### 一、GWT简介 **Google Web Toolkit (GWT)** 是由Google推出的一...随着技术的不断进步,虽然GWT可能不再是当前最流行的前端开发框架之一,但它仍然在某些特定场景下发挥着重要作用。

    GWT入门 GWT中文教程

    “GWT入门”和“GWT中文教程”显然是针对初学者的,它们可能从最基础的GWT安装、项目配置开始,逐步讲解GWT的核心概念,如UI设计(Widget系统)、事件处理、数据模型和服务器通信(RPC机制)、本地存储、国际化等。...

    GWT EXT 教程全集

    " Gwt-Ext学习笔记之基础篇.doc "、" Gwt-Ext学习笔记之中级篇.doc "、" Gwt-Ext学习笔记之进级篇.doc "这三份文档,按照从基础到进阶的顺序,系统地介绍了EXT-GWT的使用技巧和实践案例。基础篇可能涵盖EXT-GWT的...

    Gwt Designer 开发实例一

    GWT(Google Web Toolkit)Designer 是一款强大的工具,它为基于GWT的Web应用程序提供了可视化设计界面,大大简化了开发过程。在这个“Gwt Designer 开发实例一”中,我们将探讨如何利用GWT Designer来创建Composite...

    GWT

    在描述中提到的“Coral's Design”可能是指一个基于GWT的项目或者设计模式,但具体的信息没有给出。通常,这样的设计可能涉及到如何优雅地组织GWT代码结构、实现可重用的组件或遵循特定的设计原则,如MVP(Model-...

    Gwt-Ext基础-中级-进阶

    这个压缩包包含的资源是关于Gwt-Ext的基础、中级和进阶学习资料,适合想要深入理解和应用Gwt-Ext的开发者。 在"基础篇"中,你将学习到以下知识点: 1. **GWT概述**:Google Web Toolkit是一个用于构建高性能、跨...

    gwt 练习 gwt学习

    在GWT的实践中,"StockWatcher"是一个经典的入门示例,它通常用来教授GWT的基础知识。StockWatcher应用会模拟一个股票监视器,展示股票的价格变动。这个项目涉及到以下关键知识点: 1. **GWT SDK安装与设置**:首先...

    SmartGwt学习文档

    智能表单处理是SmartGwt的一个亮点,它提供了一套完整的表单组件和验证机制,方便开发者创建复杂的业务表单。同时,SmartGwt还支持国际化和本地化,方便开发面向全球用户的应用。 在实际项目中,SmartGwt通常与MVC...

    gwtext学习三部曲

    《gwtext学习三部曲》是一份专为GWT初学者设计的教程资源,它涵盖了gwtext和GWT Ext的相关知识。gwtext是Google Web Toolkit (GWT) 的一个扩展库,提供了丰富的用户界面组件和样式,使得在GWT平台上构建复杂的Web...

    smartgwt最新版本GWT的DEMO

    SmartGWT是基于Google Web Toolkit (GWT) 的一个开源框架,它为开发富互联网应用程序(RIA)提供了丰富的组件库和高级功能。SmartGWT的最新版本进一步提升了用户体验,简化了开发过程,提供了更多现代Web设计的需求...

    Gwt-Ext学习笔记之进级篇

    在深入探讨GWT-Ext之前,我们先了解一下GWT(Google Web Toolkit)和Ext Js的基础。GWT是一个开源的开发工具,允许开发者使用Java语言来编写客户端的Web应用程序,然后将其编译为优化过的JavaScript代码,以实现高...

    “深入浅出Ext“

    《深入浅出Ext》是一本专注于讲解ExtJS框架的书籍,该书旨在帮助读者深入了解ExtJS的内部工作原理,从而更好地运用这个强大的JavaScript库来构建富客户端应用。ExtJS是一个用于构建Web应用程序的前端框架,它提供了...

    GWT入门教程+实例代码

    **GWT 入门教程与实例解析** Google Web Toolkit(GWT)是Google推出的一款用于构建高性能、跨浏览器的Web应用程序的开源开发工具。...通过深入学习GWT,开发者可以构建出复杂且具有交互性的Web应用程序。

    smartGWT 3.1 最新版本

    在本篇文章中,我们将深入探讨SmartGWT 3.1的关键特性、API使用、源码解析以及Sample示例。 1. **SmartGWT框架概述** SmartGWT是一个基于Google Web Toolkit (GWT) 的扩展框架,它通过提供大量预定义的用户界面...

    一个简单的GWT示例

    **GWT 概述** Google Web Toolkit (GWT) 是一个开源的开发工具,...总之,这个GWT股票示例是一个很好的学习资源,它涵盖了GWT的基础特性,同时也提供了实践的机会,帮助开发者加深对GWT框架的认识,提升Web开发技能。

    GWT开发者手册 GWT

    - GWT的设计考虑到了跨浏览器的兼容性问题,使得开发者能够专注于应用程序的开发而不是浏览器间的差异处理。手册中提到的应用程序能够在最新的Internet Explorer、Firefox和Safari浏览器中表现出一致的行为。 #### ...

    进阶GWT,属于GWT的详细描述

    GWT开发基础知识点 在本资源中,我们将讨论Google Web Toolkit(GWT)的基础知识点,包括GWT的安装、配置、编码基础和客户端代码编写等方面的内容。 GWT安装和配置 在Eclipse中添加GWT插件是使用GWT开发的第一步...

Global site tag (gtag.js) - Google Analytics