Extjs Form用法详解

Form和Form Basicjson

Extjs Form和Form Basic是两个东西,Form提供界面的展现,而Form Basic则提供数据的处理、验证等功能。每个Form Panel在建立的时候,都会绑定一个Form Basic,咱们能够经过方法getForm来获取:服务器

form.getForm()

在API方面,Form的config中没有显示Form Basic的config,可是Form Basic的config在Form的config中彻底有效,也就是说,当咱们使用Extjs Form的时候,不单单要查看Form的API文档,还要浏览相关的Form Basic的文档。并发

建立Extjs Form控件

var form = Ext.create("Ext.form.Panel", {
    width: 500,
    height: 300,
    margin: 20,
    title: "Form",
    renderTo: Ext.getBody(),
    collapsible: true,  //可折叠
    autoScroll: true,   //自动建立滚动条
    defaultType: 'textfield',
    defaults: {
        anchor: '100%',
    },
    fieldDefaults: {
        labelWidth: 80,
        labelAlign: "left",
        flex: 1,
        margin: 5
    },
    items: [
        {
            xtype: "container",
            layout: "hbox",
            items: [
                { xtype: "textfield", name: "name", fieldLabel: "姓名", allowBlank: false },
                { xtype: "numberfield", name: "age", fieldLabel: "年龄", decimalPrecision: 0, vtype: "age" }
            ]
        },
        {
            xtype: "container",
            layout: "hbox",
            items: [
                { xtype: "textfield", name: "phone", fieldLabel: "电话", allowBlank: false, emptyText: "电话或手机号码" },
                { xtype: "textfield", name: "phone", fieldLabel: "邮箱", allowBlank: false, emptyText: "Email地址", vtype: "email" }
            ]
        },
        {
            xtype: "textareafield",
            name: "remark",
            fieldLabel: "备注",
            height: 50
        }
    ],
    buttons: [
        { xtype: "button", text: "保存" }
    ]
});

以上代码将建立一个Form表单,效果以下:app

 

Extjs Form布局

在Extjs Form中,默认的布局方式是layout: 'anchor',具体的Extjs 布局能够参考个人Extjs 布局系统详解这篇文章。异步

anchor默认每行只显示一个控件,若是咱们要在一行中显示多个,须要将这些控件放在一个container中,并设置container的layout为hbox。布局

 

Extjs Form加载数据

Form能够加载Model数据,也能够加载Json数据,这样咱们能够方便的将json或者record数据显示在Extjs Form控件中。flex

加载Record数据

Extjs Form经过方法loadRecord加载record,代码以下:url

var userRecord = Ext.create("MyApp.model.User", {
    name: "Tom",
    age: 25,
    phone: "123456"
});

form.loadRecord(userRecord);

加载Json数据

Extjs Form能够经过调用formbasic的setValues方法来加载json数据,代码以下:spa

var data = {
    name: "Tom",
    age: 25,
    phone: "123456"
};
form.getForm().setValues(data);

Extjs Form获取与更新数据

经过上面的方法,咱们能够为Form加载record或json数据。当咱们完成编辑以后,还须要获取编辑后的数据,或者将编辑后的数据更新到对应的record中,Extjs Form提供了相应的方法来完成这些操做。orm

若是Extjs Form加载的是record:

form.updateRecord();

若是Extjs Form加载的是json数据:

form.getForm().getValues()

Extjs Form异步加载与提交

Extjs Form除了能够加载页面中已存在的数据外,还能够经过Ajax的方式异步加载与提交数据。这种方法不太经常使用。

异步加载

form.getForm().load({
    url: "form-data.ashx"
});

服务器返回的数据格式以下:

{
    success:true,
    data:{
        name: "Tom",
        age: 25,
        phone: "123456"
    }
}

异步提交

form.submit({
    url: "form-submit.ashx",
    success: function (form, action) {
        Ext.Msg.alert('Success', action.result.msg);
    }
});

submit方法提交的数据为Form中的全部value,能够在服务器端获取到。

本文由齐飞(youring2@gmail.com)原创,并发布在http://www.qeefee.com/article/extjs-form-in-detail,转载请注明出处!推荐更多Extjs教程Extjs5教程

Extjs Form验证

在全部开发语言中,客户端验证是必不可少的。Extjs Form也提供了客户端验证机制,咱们能够经过vtype来实现客户端验证。接下来咱们详细的了解一下Extjs的客户端验证。

必填项,就是不能为空(allowBlank)

效果:

 

代码:

{
    xtype: "textfield",
    name: "UserName",
    fieldLabel: "用户名",
    allowBlank: false,
    flex: 1
}

输入长度限制,maxLength/minLength

效果:

 

&

 

代码:

{
    xtype: "textfield",
    name: "UserName",
    fieldLabel: "用户名",
    allowBlank: false,
    maxLength: 10,
    minLength: 3,
    flex: 1
}

值大小限制,maxValue/minValue

值大小的限制经常使用于numberfield、datefield,能够指定一个可用值的范围。

效果:

 

&

 

代码:

{
    xtype: "numberfield",
    name: "Age",
    fieldLabel: "年龄",
    maxValue: 60,
    minValue: 18,
    flex: 1
}

vtype验证

vtype提供了一些公用的验证类型,它们包括:

  • alpha:希腊数字
  • alphanum:字母和数字
  • email:电子邮件地址
  • url:网址

这四种是extjs内置的,已经提供给咱们能够直接来用的。咱们拿email来进行示例。

效果:

 

代码:

{
    xtype: "textfield",
    name: "Email",
    fieldLabel: "Email",
    vtype: "email",
    flex: 1
}

自定义vtype

上面介绍了vtype的简单用法,能够看到这种验证是很是好用的,可是小伙伴们不以为extjs提供的vtype太少吗?

小伙伴们不要嫌弃,接下来咱们看一下如何自定义vtype,代码:

//验证ip地址
Ext.apply(Ext.form.field.VTypes, {
    IPAddress: function (v) {
        return /^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/.test(v);
    },
    IPAddressText: '只能输入ip地址',
    IPAddressMask: /[\d\.]/i
});

用法:

{
    xtype: "textfield",
    name: "ip",
    fieldLabel: "IP地址",
    vtype: "IPAddress"
}

效果:

相关文章
相关标签/搜索