Extjs之form(2)

本文接着上讲 Extjs学习笔记之二-初识Extjs之from 介绍Extjs的表单。Extjs除了类似普通的html form的表单项之外,还有一些功能更为丰富实用的表单项。

1.日期选择框,DateField

日期选择框在日常项目中被广泛应用,一个方便的日期输入机制能够极大的提高用户体验。Extjs的DateField非常友好灵活强大。可以通过如下代码新建一个日期选择框:

注意,默认情况下,这个日历显示的是英文,如果需要显示中文,需要引入区域文件:

<script type="text/javascript" src=\'#\'" /src/locale/ext-lang-zh_CN.js"></script>

2.HTML编辑器,HTMLEditor

HTML编辑器可以使客户编辑html文档。启用HTML编辑器非常简单,而且几乎不需要额外的配置,默认的就很好用:

遗憾的是这个编辑器不支持图文混排,不过对于轻量级的应用来说还是很好用的。如果需要图文混排还是使用专门的第三方的插件好了。

3.组合框, ComboBox

这是一个重量级的控件,因为它在实际应用中起着广泛而重要的作用。虽然它的使用频率没有 TextField高,但是它的功能却比TestField 丰富的多,所以把它放在比较靠后的位置来介绍。Extjs的ComboBox具有下拉提示,自动完成等功能,也同时支持本地和服务器端的数据源。下面先看 一个本地数据源的示例。

本地数据源可以放在一个ArrayStore中,这是一个类似一个数组的结构。例如,可以定义下面的store:

下面就可以添加一个combobox,

  1. var myform = new Ext.FormPanel({
  2.                 applyTo: 'myform',
  3.                 title: 'ComboxBox with local datasource',
  4.                 height: 200,
  5.                 width: 300,
  6.                 frame: true,
  7.                 labelSeparator: ':',
  8.                 labelWidth: 60,
  9.                 labelAlign: 'right',
  10.                 items: [new Ext.form.ComboBox({
  11.                     id:'combolocal',
  12.                     fieldLabel:'部门',
  13.                     triggerAction:'all',
  14.                     store:store,
  15.                     displayField:'Name',
  16.                     mode:'local',
  17.                     forceSelection:true,
  18.                     typeAhead:true,
  19.                     resizable:true})
  20.             ]
  21.             });

其中比较重要的配置项有displayField,对应的是datastore中的fields,用来指定显示哪个字段。mode,在这里是 local,表示本地数据源。typeAhead表示是否自动完成,forceSelection表示是否仅允许用户输入下拉列表中有的数据。。效果如下, 下图展示了自动完成,我仅在输入框中输入了一个“开”字:

使用远程数据也是类似的,不过我们首先要准备好一个能够返回数据的服务器页面,新建一个combo.ashx代码如下:

  1. public class combo : IHttpHandler {   
  2.     public void ProcessRequest (HttpContext context) {
  3.         string query = context.Request.Params["search"];       
  4.         StringBuilder sb = new StringBuilder("[");
  5.         foreach (string s in data)
  6.             if (s.Contains(query)||query=="all") sb.Append(s+",");
  7.         if(sb[sb.Length-1]==',')
  8.             sb.Remove(sb.Length - 1, 1);
  9.         sb.Append("]");       
  10.         context.Response.ContentType = "text/plain";
  11.         context.Response.Write(sb.ToString());
  12.     }   
  13.     string[] data=new string[]{"['开发部', 1]","['行政部', 2]", "['销售部', 3]", "['质检部', 4]", "['售后部', 5]"};
  14.  
  15.     public bool IsReusable {
  16.         get {
  17.             return false;
  18.         }
  19.     }}

 

此段程序根据客户端传来的参数进行筛选,再传回数据,如果参数值是all,则返回全部数据。可见服务器端的自动完成可以比本地的更自由,当然速度也会更 慢。这个例子中服务器传回的一个符合格式的javascript数组,在实际开发中,有更好的数据传送格式可以选择,本文的讨论重点不是数据的传递,因此 就直接采用这种方式作为示例。接下来配置下客户端的datastore:

  1. var remoteStore=new Ext.data.ArrayStore({
  2.                     fields: ['Name', 'Code'],
  3.                     proxy:new Ext.data.HttpProxy({url:'Combo.ashx'})
  4.                 });

最后就可以创建一个使用远程数据源的combobox了:

  1. new Ext.form.ComboBox({
  2.                 id: 'comboremote',
  3.                     allQuery:'all',
  4.                     fieldLabel: '远程部门',
  5.                     triggerAction: 'all',
  6.                     mode: 'remote',
  7.                     queryParam:'search',
  8.                     displayField:'Name',
  9.                     store:remoteStore,
  10.                     minChars:1})

其中minChars表示用户至少要输入多少字后才开始自动完成,queryParam是向服务器传递参数的名字,allQuery是要求返回全部数据时候的参数值。效果如下:

在remote模式下,combobox还支持服务器端分页,此时combox会向服务器传递start和limit参数,表示要显示的数据范围,服务器端代码做相应处理后返回数据即可。

你可能感兴趣的:(form,表单,职场,ExtJs,休闲)