Extjs之grid单元格编辑校验

效果如图所示:

1. 添加CSS样式
<style>
.x-grid-cell-invalid .x-grid-cell-inner:before{content: "";position: absolute;z-index: 0;top: 0;bottom: 0;left: 0;right: 0;border: 1px solid red;}
</style>
2. 监听单元格编辑插件的事件
{ptype: 'cellediting', clicksToEdit: 1, pluginId: 'edit',listeners:{
//单元格编辑完成之后会触发此事件
validateedit:function(editor,context,eOpts){
//字段名判断
if(context.field==="typeId") {
//后台校验
Ext.Ajax.request({
url: '/service/articleTypeService/uniquenessCheck',
params: {id: context.value},
success: function (obj) {
if (obj.success === false) {
//校验未通过后给单元格添加class
var node=Ext.get(context.node);
var td=node.query('[data-columnid='+context.column.id+']',false)[0];
td.addCls("x-grid-cell-invalid invalid-id");
}
},
loadMask:false
});
}
return true;
}
}}
3. 给未校验通过的单元格添加tooltip提示
//表格事件监听
listeners:{
afterrender:function(view){
Ext.create('Ext.tip.ToolTip',{
target:view.el,
delegate:'.invalid-id',
html:'<span style="color:red">无效的ID,ID重复</span>'
});
}
}
4. 当表格渲染时就想进行验证的时候使用的方式(可省略第2步)
{xtype:'textcolumn',text: '编码', dataIndex: 'typeId', align: 'left', flex: 1,editor:{}
,renderer:function(value,metaData,record,rowIndex,colIndex,store,view){
if(value==40){
metaData.tdCls="x-grid-cell-invalid invalid-age";
}
return value;}
}
5.校验
invalid:function(){
var tds=this.getView().getEl().query('td.x-grid-cell-invalid');
return tds.length>0;
},
备注:在Extjs5.1下测试通过,写的都是些代码片段,相信大家都看明白其中含义。

转载于:https://www.cnblogs.com/jiawenjun/p/6590709.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值