form panel


<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Ext JS in Action Chapter 06 | Listing 6.4 Implementing a remote combobox</title>
<link rel="stylesheet" type="text/css" href="./ext3/resources/css/ext-all.css" />
<script type="text/javascript" src="./ext3/adapter/ext/ext-base.js"></script>
<script type="text/javascript" src="./ext3/ext-all.js"></script>
</head>
<body>

<script type="text/javascript">
Ext.onReady(function() {
Ext.QuickTips.init();
var remoteJsonStore = new Ext.data.JsonStore({
root : 'records',
totalProperty : 'totalCount',
baseParams : {
column : 'fullName'
},
fields : [
{
name : 'name',
mapping : 'fullName'
},
{
name : 'id',
mapping : 'id'
}
],
proxy : new Ext.data.ScriptTagProxy({
url : 'http://extjsinaction.com/dataQuery.php'
})
});

var combo = {
xtype : 'combo',
fieldLabel : 'Search by name',
forceSelection : true,
displayField : 'name',
valueField : 'id',
hiddenName : 'customerId',
loadingText : 'Querying....',
pageSize : 5,
minChars : 1,
triggerAction : 'all',
store : remoteJsonStore
};

var onSuccessOrFail = function(form, action) {
var formPanel = Ext.getCmp('myFormPanel');
formPanel.el.unmask();

var result = action.result;
if (result.success) {
Ext.MessageBox.alert('Success',action.result.msg);
}
else {
Ext.MessageBox.alert('Failure',action.result.msg);
}
};


var submitHandler = function() {
var formPanel = Ext.getCmp('myFormPanel');
formPanel.el.mask('Please wait', 'x-mask-loading');

formPanel.getForm().submit({
url : 'newbackgroundprograma.action',
success : onSuccessOrFail,
failure : onSuccessOrFail
});

};

var buttons = [
{
text : 'Submit',
handler : submitHandler
},
{
text : 'load'
}
];

var fp = new Ext.form.FormPanel({
renderTo : Ext.getBody(),
labelWidth : 100,
bodyStyle : 'padding: 5px',
width : 600,
id : 'myFormPanel',
title : 'Our complex form',
height : 350,
frame : true,
layout : 'form',
layoutConfig : {
align : 'stretch'
},
items : [
combo
],
buttons : buttons
});

});


</script>
</body>
</html>
后台action可以用request.getparameter("customerId");取得id的值,这就是hiddenName的作用



{success: true, msg : 'Form submitted successfully'}



{success: false, msg : 'This is an example error message', errors : {firstName : 'Cannot contain "!" characters.',lastName : 'Must not be blank.'}}
### Ext.form.Panel组件详细介绍 #### 组件定位 对于传统的B/S应用,数据录入元素通常置于表单标签内;而在ExtJS应用中,可以直接使用`Ext.form.Panel`(即`FormPanel`)控件存放表单中的元素。`FormPanel`继承自`Panel`,在`Panel`基础上提供了与表单相关的特性 [^2]。 #### 支持的主要表单组件 `Ext.form.Panel`支持一系列的表单组件,以下是部分常见组件及其`xtype`类型: | 组件名称 | xtype类型 | | --- | --- | | 复选框 | checkboxfield | | 复选框组 | checkboxgroup | | 下拉列表框 | combo | | 日期选择框 | datefield | | 文本显示组件 | displayfield | | 字段容器 | fieldcontainer | | 字段集 | fieldset | | 隐藏域 | hiddenfield | | HTML文本编辑器 | htmleditor | | 标签字段 | label | | 数字输入框 | numberfield | | 单选框 | radio | | 单选框组 | radiogroup | | 微调组件 | spinnerfield | | 多行文本框 | textareafield | | 单行文本框 | textfield | | 时间选择框 | timefield | | 触发器按钮文本框 | triggerfield | | 文本框上传字段 | filefield | [^1] #### 常用方法 | 方法名 | 说明 | | --- | --- | | checkChange(): void | 强制检查每个表单字段是否发生了变化 | | getForm(): Ext.form.BasicForm | 获取表单面板对应的基本表单对象 | | load(Object options): void | 加载表单内容 | | startPolling(Number interval): void | 开启轮询,具体间隔时间由`interval`参数指定(文档未详细说明此方法效果) | [^3] ### 使用示例 以下是一个简单的`Ext.form.Panel`使用示例代码: ```javascript Ext.onReady(function() { // 创建表单面板 var formPanel = Ext.create('Ext.form.Panel', { title: '示例表单', width: 300, bodyPadding: 10, renderTo: Ext.getBody(), url: 'submit-form.php', // 表单提交的URL method: 'POST', // 表单提交方式 // 定义表单中的字段 items: [ { xtype: 'textfield', fieldLabel: '用户名', name: 'username', allowBlank: false // 不允许为空 }, { xtype: 'textareafield', fieldLabel: '备注', name: 'remark', grow: true // 文本框根据内容自动增长 }, { xtype: 'datefield', fieldLabel: '日期', name: 'date', format: 'Y-m-d' // 日期格式 } ], // 定义表单底部的按钮 buttons: [ { text: '提交', handler: function() { if (formPanel.getForm().isValid()) { // 检查表单字段是否有效 formPanel.getForm().submit({ success: function(form, action) { Ext.Msg.alert('成功', '表单提交成功'); }, failure: function(form, action) { Ext.Msg.alert('失败', '表单提交失败'); } }); } } }, { text: '重置', handler: function() { formPanel.getForm().reset(); // 重置表单内容 } } ] }); }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值