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.'}}
安全帽与口罩检测数据集 一、基础信息 数据集名称:安全帽与口罩检测数据集 图片数量: - 训练集:1690张图片 - 验证集:212张图片 - 测试集:211张图片 - 总计:2113张实际场景图片 分类类别: - HelmetHelmet:戴安全帽的人员,用于安全防护场景的检测。 - personwithmask:戴口罩的人员,适用于公共卫生监测。 - personwith_outmask:未戴口罩的人员,用于识别未遵守口罩佩戴规定的情况。 标注格式:YOLO格式,包含边界框和类别标签,适用于目标检测任务。 数据格式:JPEG/PNG图片,来源于实际监控和场景采集,细节清晰。 二、适用场景 工业安全监控系统开发: 数据集支持目标检测任务,帮助构建自动检测人员是否佩戴安全帽的AI模型,适用于建筑工地、工厂等环境,提升安全管理效率。 公共卫生管理应用: 集成至公共场所监控系统,实时监测口罩佩戴情况,为疫情防控提供自动化支持,辅助合规检查。 智能安防与合规检查: 用于企业和机构的自动化安全审计,减少人工干预,提高检查准确性和响应速度。 学术研究与AI创新: 支持计算机视觉目标检测领域的研究,适用于安全与健康相关的AI模型开发和论文发表。 三、数据集优势 精准标注与实用性: 每张图片均经过标注,边界框定位准确,类别定义清晰,确保模型训练的高效性和可靠性。 场景多样性与覆盖性: 包含安全帽和口罩相关类别,覆盖工业、公共场所以及多种实际环境,样本丰富,提升模型的泛化能力和适应性。 任务适配性强: 标注兼容主流深度学习框架(如YOLO),可直接用于目标检测任务,便于快速集成和部署。 实际应用价值突出: 专注于工业安全和公共健康领域,为自动化监控、合规管理以及疫情防护提供可靠数据支撑,具有较高的社会和经济价值。
内容概要:本文围绕FOC电机控制代码实现与调试技巧在计算机竞赛中的应用,系统阐述了从基础理论到多场景优化的完整技术链条。文章深入解析了磁链观测器、前馈控制、代码可移植性等关键概念,并结合FreeRTOS多任务调度、滑动窗口滤波、数据校验与热仿真等核心技巧,展示了高实时性与稳定性的电机控制系统设计方法。通过服务机器人、工业机械臂、新能源赛车等典型应用场景,论证了FOC在复杂系统协同中的关键技术价值。配套的千行级代码案例聚焦分层架构与任务同步机制,强化工程实践能力。最后展望数字孪生、低代码平台与边缘AI等未来趋势,体现技术前瞻性。; 适合人群:具备嵌入式开发基础、熟悉C语言与实时操作系统(如FreeRTOS)的高校学生或参赛开发者,尤其适合参与智能车、机器人等综合性竞赛的研发人员(经验1-3年为佳)。; 使用场景及目标:① 掌握FOC在多任务环境下的实时控制实现;② 学习抗干扰滤波、无传感器控制、跨平台调试等竞赛实用技术;③ 提升复杂机电系统的问题分析与优化能力; 阅读建议:此资源强调实战导向,建议结合STM32等开发平台边学边练,重点关注任务优先级设置、滤波算法性能权衡与观测器稳定性优化,并利用Tracealyzer等工具进行可视化调试,深入理解代码与系统动态行为的关系。
### 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、付费专栏及课程。

余额充值