Ext Grid的Combo/TextField/Width/Height的问题

本文介绍了一个使用ExtJS实现的可编辑Grid案例,包括如何设置列宽高、使用ComboBox实现下拉选择,并讨论了显示字段的问题及解决方案。
Ext.onReady(function(){
var fm = Ext.form;

var checkColumn = new Ext.grid.CheckColumn({
header: "Indoor?",
dataIndex: 'indoor',
width: 55
});
var cm = new Ext.grid.ColumnModel([{
id:'common',
header: "Common Name",
dataIndex: 'common',
width: 220,
editor: new fm.TextField({
allowBlank: false
})
},{
header: "Light",
dataIndex: 'light',
width: 130,
editor: new Ext.form.ComboBox({
displayField: ,
typeAhead: true,
triggerAction: 'all',
transform:'light',
lazyRender:true,
listClass: 'x-combo-list-small'
})
},{
header: "Price",
dataIndex: 'price',
width: 70,
align: 'right',
renderer: 'usMoney',
editor: new fm.NumberField({
allowBlank: false,
allowNegative: false,
maxValue: 100000
})
},{
header: "Available",
dataIndex: 'availDate',
width: 95,
renderer: formatDate,
editor: new fm.DateField({
format: 'm/d/y',
minValue: '01/01/06',
disabledDays: [0, 6],
disabledDaysText: 'Plants are not available on the weekends'
})
},
checkColumn
]);

cm.defaultSortable = true;

var Plant = Ext.data.Record.create([
{name: 'common', type: 'string'},
{name: 'botanical', type: 'string'},
{name: 'light'},
{name: 'price', type: 'float'},
{name: 'availDate', mapping: 'availability', type: 'date', dateFormat: 'm/d/Y'},
{name: 'indoor', type: 'bool'}
]);

var ds = new Ext.data.Store({
url: 'plants.xml',

reader: new Ext.data.XmlReader({
record: 'plant'
}, Plant),

sortInfo:{field:'common', direction:'ASC'}
});

var grid = new Ext.grid.EditorGridPanel({
ds: ds,
cm: cm,
renderTo: 'editor-grid',
width:600,
height:300,
autoExpandColumn:'common',
title:'Edit Plants?',
frame:true,
plugins:checkColumn,
clicksToEdit:1,

tbar: [{
text: 'Add Plant',
handler : function(){
var p = new Plant({
common: 'New Plant 1',
light: 'Mostly Shade',
price: 0,
availDate: new Date(),
indoor: false
});
grid.stopEditing();
ds.insert(0, p);
grid.startEditing(0, 0);
}
}]
});

ds.load();
});
这是Ext grid中的可编辑的grid的Demo,
它在设置width/heigth用的是number,在Api中也是这样讲的,大家有用百分比的做法么?
另外在它的Editor中用了ComboBox,下拉选择列表后会把valueField的值显示出来,而不是把displayFiled显示出来,同样的问题存在于textFiled中,当inputType=password时,输入的时候显示为*,但是输入完成后仍然会把原值显示出来,这个问题大家怎么解决呢!
init: function () { var param = new HashMap(); param.put('operate', 'getParam'); Rpc({ functionId: 'GZ00002301', async: false, success: function (data) { var result = Ext.decode(data.responseText); if (result.return_code == 'success') { var returnData = result.return_data; var params = returnData.paramMap; approvalparameter_me.allSalarySet = params.salaryTypeList; approvalparameter_me.salaryMainArr = params.approvalParamList; approvalparameter_me.flowableList = params.flowableList approvalparameter_me.org_id = params.org_id console.log(params) } } }, param); var showData = []; var data = approvalparameter_me.salaryMainArr Ext.each(data, function (item, index) { showData.push(item); }); data.push({ operate:true, id: '', name: '', salary_table: '', salary_type: '', appeal_user: '', approval_report: '', approval_flow: '', approval_org: '' }); //grid面板 的Store approvalparameter_me.mianStore = Ext.create('Ext.data.Store', { storeId: 'mainStore', // 增加排序字段 fields: ['operate','id', 'name', 'salary_table','salary_name', 'salary_type', 'appeal_user', 'approval_report', 'approval_flow','approval_flow_name', 'approval_org', 'approval_org_name'], // 自动加载 data: data }); var states = Ext.create('Ext.data.Store', { id: 'flowableStore', fields: ['dataName', 'dataValue'] }); Ext.each(approvalparameter_me.flowableList, function (obj, index) { states.insert(index, [{dataName: obj.dataName, dataValue: obj.dataValue}]); }); //界面的grid面板 var salaryGrid = Ext.create("Ext.grid.Panel", { store: approvalparameter_me.mianStore, itemId: "salaryGrid", id:'approvalParameterPanel', border: false, bodyStyle: "margin-top:1px;", enableColumnResize: true,//改变列宽 enableColumnMove: false,//拖放列 stripeRows: false,//表格是否隔行换色 columnLines: true,//列分割线 selModel: Ext.create("Ext.selection.CheckboxModel", { mode: "multi",//multi,simple,single;默认为多选multi checkOnly: true,//如果值为true,则只用点击checkbox列才能选中此条记录 enableKeyNav: true, renderer: function (value, metaData, record, rowIndex, colIndex, store, view) { if (record.data.operate) { metaData.tdStyle = 'border-width:0px !important'; //去除操作行的分割线 return "<i class='hj-line hj-line-xinzeng' data-qtip='新增' style='font-size: 18px;cursor:pointer;' onclick='approvalparameter_me.addData()'/>"; }else { return '<span class="' + Ext.baseCSSPrefix + 'grid-checkcolumn" role="presentation"></span>' } } }), viewConfig: { markDirty: false // 禁用脏数据标记 }, columns: [//名称 { text: '名称', dataIndex: 'name', sortable: false, hideable: false, align: 'left', width: 180, editor: { xtype: 'textfield', // 这里定义编辑器的类型 allowBlank: false, listeners: { // 监听编辑完成事件 blur: function(field) { var editor = field.up('editor'); // 获取编辑器组件 var record = editor.context.record; // 获取当前编辑的记录 console.log('当前行数据:', record.data); console.log('字段名:', editor.context.column.dataIndex); console.log('行索引:', editor.context.rowIdx); var currentid = record.data.id; var param = new HashMap(); param.put('operate', 'save'); param.put('opt', 'saveName'); param.put("id", currentid); param.put("value", field.value); Rpc({ functionId: 'GZ00002301', async: false, success: function (data) { var result = Ext.decode(data.responseText); if (result.return_code == 'success') { var returnData = result.return_data; //record.data.id开头是ext,更新record.data.id 为params.returnValue if (record.data.id && record.data.id.toString().startsWith('ext')) { // 更新record.data.id为params.returnValue record.set('id', returnData.returnValue); console.log('更新ID:', returnData.returnValue); } } } }, param); } } }, renderer: function (value, metaData, record, rowIndex, colIndex, store, view) { var html = value; if (record.data.operate) { metaData.tdStyle = 'border-width:0px !important'; //去除操作行的分割线 } if (record.data.operate) { html= "<i class='hj-line hj-line-shanchu' data-qtip='删除' style='font-size: 18px;cursor:pointer;' onclick='approvalparameter_me.delData()'/>"; } return html; } },// 薪资类别 { text: '薪资类别', dataIndex: 'salary_name', sortable: false, hideable: false, align: 'left', width: 300, renderer: function (value, metaData, record, rowIndex, colIndex, store, view) { if (record.data.operate) { metaData.tdStyle = 'border-width:0px !important'; // 去除操作行的分割线 } else { if (!value){ value = '' } var html = '<div style="display: flex; justify-content: space-between; align-items: center; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; width: 100%;">'; // 使用 flexbox // 在此处添加 data-qtip,给出完整值 html += '<div style="text-align: left; flex-grow: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; max-width: 80%;" data-qtip="' + Ext.util.Format.htmlEncode(value) + '">' + value + '</div>'; // value 超出部分显示省略号 html += '<a onclick="approvalparameter_me.createSetSalerySetWin(\''; html += record.data.id; html += '\',\''+rowIndex+'\')"><i class="hj-line hj-line-peizhicanshu" data-qtip="' + gz.label.attribute + '"></i></a>'; html += '</div>'; return html; } } },//报批用户 { text: '报批用户', dataIndex: 'appeal_user', sortable: false, hideable: false, align: 'left', width: 180, renderer: function (value, metaData, record, rowIndex, colIndex, store, view) { if (record.data.operate) { metaData.tdStyle = 'border-width:0px !important'; //去除操作行的分割线 }else { var orgId = record.data.org_id; if (value) { var name = record.data.userfullname; if (record.data.fullname) { name+='(' + record.data.fullname + ')'; } var showName = name; var personImgId='user_name_' + record.data.id; var photoUrl =record.data.photoPath; if (photoUrl == "/images/photo.jpg") { photoUrl = rootPath+ photoUrl; } // var qtipName = recorddata.fullname?record.data.username+ '(' +record.data.fullname + ')':record.data.username; return '<div id="'+ personImgId +'"><div style="margin-top:-10px;position:relative; padding-right:8px;" data-qtip="' + name + '">' + '<img id="'+ personImgId +'_photo" width=30 height=30 onclick="approvalparameter_me.createPersonPicker(\''+ orgId +'\',\''+ rowIndex +'\', \''+ personImgId +'\', \''+ record.data.id +'\')" style="border-radius: 100%;vertical-align:middle;margin:0px 4px 0px 0px;padding-top: 0px;cursor:pointer;" src='+photoUrl+' />'+ '<span style="display:inline-block;margin-top:10px;" id="'+ personImgId +'_name">'+ showName +'</span>'+ '</div></div>'; } else { var personImgId = 'user_name_' + orgId + '_' + rowIndex; var html = '<div id="'+ personImgId +'" style="width:98%;display:flex;">'; html = html + '<i onclick="approvalparameter_me.createPersonPicker(\''+orgId+'\',\''+ rowIndex +'\', \''+ personImgId +'\', \''+ record.data.id +'\')" '; html = html + ' class="hj-workflow hj-workflow-zengjiarenwu" style="font-size: 18px;float:right;margin-right:5px;cursor:pointer;"></i>'; html = html + '<span style="float: right"></span></div>'; return html; } } } },// 审批报表 { text: '审批报表', dataIndex: 'approval_report', sortable: false, hideable: false, align: 'left', width: 100, renderer: function (value, metaData, record, rowIndex, colIndex, store, view) { if (record.data.operate) { metaData.tdStyle = 'border-width:0px !important'; //去除操作行的分割线 }else { var html = '<div style="display: flex; justify-content: center; align-items: center;">'; // 使用 flexbox 并居中 html += '<a onclick="approvalparameter_me.openProperty(\''; html += 'salaryid'; html += '\',\'' + '' + '\',\'' + '' + '\')"><i class="hj-line hj-line-peizhicanshu" data-qtip="' + gz.label.attribute + '"></i></a>'; html += '</div>'; return html; } } },// 审批流程 { text: '审批流程', dataIndex: 'approval_flow_name', sortable: false, hideable: false, align: 'left', width: 200, editor: { xtype: 'combobox', store: states, // 根据需求替换成实际的流程数据 editable: false, forceSelection: true, queryMode: 'local', displayField: 'dataName', valueField: 'dataValue', emptyText: "请选择流程", value: 'xz', listeners: { afterrender: function (combo) { combo.setValue('cs'); // 手动设置值 }, select: function (combo,newValue, oldValue) { var editor = combo.up('editor'); var grid = editor.up('gridpanel'); var rowIndex = editor.context.rowIdx; approvalparameter_me.mianStore.data.items[rowIndex].data.approval_flow = newValue.data.dataValue; approvalparameter_me.mianStore.data.items[rowIndex].data.approval_flow_name = newValue.data.dataName; var record = editor.context.record; var param = new HashMap(); param.put('operate', 'save'); param.put('opt', 'saveaApprovalFlow'); param.put("id", record.id); param.put("value", newValue.data.dataValue); Rpc({ functionId: 'GZ00002301', async: false, success: function (data) { var result = Ext.decode(data.responseText); if (result.return_code == 'success') { Ext.showAlert('保存成功!'); approvalparameter_me.mianStore.load(); } } }, param); } } }, renderer: function (value, metaData, record, rowIndex, colIndex, store, view) { if (record.data.operate) { metaData.tdStyle = 'border-width:0px !important'; //去除操作行的分割线 }else { return value; } } },// 所属组织 { text: '所属组织', dataIndex: 'approval_org_name', sortable: false, hideable: false, align: 'left', width: 220, renderer: function (value, metaData, record, rowIndex, colIndex, store, view) { if (record.data.operate) { metaData.tdStyle = 'border-width:0px !important'; //去除操作行的分割线 }else { if (!value){ value = '' } var salaryid = record.data.salaryid_safe; var html = '&nbsp&nbsp<a href="javascript:;" onclick="approvalparameter_me.openSelectPerson(this,\''+salaryid+'\',\'' + record.data.approval_org + '\',\'' + record.data.id + '\')"><i style="padding-right: 4px;" class="hj-line hj-line-zuzhijigou"></i>'+value+'</a>'; return html; } } } ], plugins: [ Ext.create('Ext.grid.plugin.CellEditing', { // 添加单元格编辑插件 clicksToEdit: 1 // 单击一次进入编辑状态 }) ], listeners: { cellclick: function (grid, td, cellIndex, record, tr, rowIndex, e, options) { // 判断点击的列是否是审批流程列 if (cellIndex === grid.getColumnManager().getHeaderIndex('审批流程')) { // 启动单元格编辑 grid.getPlugin().startEdit(record, cellIndex); } } } }); approvalparameter_me.add(salaryGrid); }最后一行数据的operate为true
08-26
内容概要:本文围绕SecureCRT自动化脚本开发在毕业设计中的应用,系统介绍了如何利用SecureCRT的脚本功能(支持Python、VBScript等)提升计算机、网络工程等相关专业毕业设计的效率与质量。文章从关键概念入手,阐明了SecureCRT脚本的核心对象(如crt、Screen、Session)及其在解决多设备调试、重复操作、跨场景验证等毕业设计常见痛点中的价值。通过三个典型应用场景——网络设备配置一致性验证、嵌入式系统稳定性测试、云平台CLI兼容性测试,展示了脚本的实际赋能效果,并以Python实现的交换机端口安全配置验证脚本为例,深入解析了会话管理、屏幕同步、输出解析、异常处理和结果导出等关键技术细节。最后展望了低代码化、AI辅助调试和云边协同等未来发展趋势。; 适合人群:计算机、网络工程、物联网、云计算等相关专业,具备一定编程基础(尤其是Python)的本科或研究生毕业生,以及需要进行设备自动化操作的科研人员; 使用场景及目标:①实现批量网络设备配置的自动验证与报告生成;②长时间自动化采集嵌入式系统串口数据;③批量执行云平台CLI命令并分析兼容性差异;目标是提升毕业设计的操作效率、增强实验可复现性与数据严谨性; 阅读建议:建议读者结合自身毕业设计课题,参考文中代码案例进行本地实践,重点关注异常处理机制与正则表达式的适配,并注意敏感信息(如密码)的加密管理,同时可探索将脚本与外部工具(如Excel、数据库)集成以增强结果分析能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值