ExtJs 实现表单联动

简介: 最近做的项目使用Extjs。遇到表单联动的业务。下面来说说主要实现思想:说明:表单联动一般存在从属关系,有大范围的对象和大范围中的小对象。比如地理位置的选定(例:浙江省-杭州市-某某县)。在这里,我将大范围的对象称为包含对象,大范围中的小对象称为被包含对象。

最近做的项目使用Extjs。遇到表单联动的业务。下面来说说主要实现思想:

说明:表单联动一般存在从属关系,有大范围的对象和大范围中的小对象。比如地理位置的选定(例:浙江省-杭州市-某某县)。在这里,我将大范围的对象称为包含对象,大范围中的小对象称为被包含对象。

表单联动针对ComboBox(组合框)。在实现时,将包含对象传入被包含对象中,在后台查询被包含对象时,使用传入的包含对象的某个值(一般为被包含对象的外键)作为condition,查询与其相关的被包含对象。实现指定的被包含对象查询。

还有一点注意的是:在将大范围对象传入小对象后,使用js的监听机制,监听当小对象(组合框)要expand(展开)时,加载与其大范围对象相关的所有小对象。这里通过一个大范围对象的某个参数作为查询小对象的条件。两个对象一般存在外键关联的关系。

实例化表单的代码

var chejianObject = new ChejianBox("所属车间","chejianId"); //实例化车间
var banzuObject = new BanzuBox("班组","emp.banzuId",chejianObject); //实例化班组
banzuObject.on('expand', function(comboBox){
    var chejianId = Ext.getCmp("chejianValue所属车间").getValue();
    this.getStore().load({
        params: {
        chejianId: chejianId
    }
    });
});

定义表单的代码

//班组定义
BanzuBox = Ext.extend(Ext.form.ComboBox,{
    constructor: function(labelName,hiddenName, chejianObject){
        //与部门表进行级联操作
    chejianObject.on('select', function(comboBox){
        var value = comboBox.getValue();
        Ext.getCmp('banzuValue'+labelName).setRawValue('');
        banzuStore.reload({
                params: {chejianId: value}
        });
    });
    BanzuBox.superclass.constructor.call(this,{
        id: 'banzuValue'+labelName,
        fieldLabel: labelName,
        displayField: 'banzuName',
        valueField: 'banzuId',
        hiddenName: hiddenName,
        width: 100,
        emptyText: '请选择',
        height: 100,
        store: banzuStore,
        triggerAction: 'all', //显示所有
        editable: false,
        allowBlank: false,
        msgTarget: 'side',
        blankText: '请选择'
    });
    }
});
//车间定义
ChejianBox = Ext.extend(Ext.form.ComboBox,{
    chejianStore: null,
    //注意传入参数labelName,因为其作id的一部分,避免出现相同的id
    constructor: function(labelName, hiddenName){
        chejianStore = new Ext.data.JsonStore({
        autoLoad: true, //设为自动加载,以便实现修改时选中某值
        url:'chejian_show.action',
        fields: ['chejianId','chejianName']
        });
    ChejianBox.superclass.constructor.call(this,{
        id: 'chejianValue'+labelName,
        fieldLabel: labelName,
        displayField: 'chejianName',
        valueField: 'chejianId',
        emptyText: '请选择',
        hiddenName: hiddenName,
        width: 100,
        store: chejianStore,
        triggerAction: 'all', //显示所有
        editable: false,
        allowBlank: false,
        msgTarget: 'side',
        blankText: '请选择'
    });
    }
});
相关文章
|
JavaScript 前端开发 容器
Element概述、入门案例及布局
Element概述、入门案例及布局
226 0
|
11月前
|
存储 消息中间件 缓存
Redis 简介
10月更文挑战第14天
284 58
|
传感器 机器学习/深度学习 自动驾驶
未来出行的革新:无人驾驶技术深度解析
在当今科技飞速发展的时代,无人驾驶技术正逐步从科幻走向现实,成为未来交通领域最具革命性的变化之一。本文旨在深入探讨无人驾驶技术的工作原理、关键技术组件以及面临的伦理与法律挑战,并展望其对社会经济和日常生活的深远影响。通过分析感知、决策和执行三个核心环节,本文揭示了无人驾驶汽车如何利用先进的传感器阵列、复杂的算法和精密的机械控制来实现自主行驶。同时,文章也讨论了数据安全、隐私保护及责任归属等问题,呼吁建立相应的法规框架以促进技术的健康发展。最后,无人驾驶技术被预测将为减少交通事故、缓解拥堵、提高能效及推动共享经济等方面带来显著益处,预示着一个更加智能、高效和可持续的出行未来。
|
11月前
|
弹性计算 网络协议 网络安全
内网DNS解析&VPN网关联动实现云上访问云下资源
内网DNS解析&VPN网关联动实现云上访问云下资源
|
存储 云安全 安全
云端数据加密实践
【7月更文挑战第12天】云端数据加密是保障云端数据安全的重要手段。通过选择合适的加密方式、加强加密密钥管理、实施静态与动态数据加密、采用加密信息检索技术和应用层加密组件等措施,可以有效地保护云端数据的安全。未来,随着技术的不断进步和应用需求的多样化,云端数据加密技术将继续发挥其重要作用,为各种应用场景提供强大的安全保障。
|
安全 测试技术 Linux
浅谈黑客赚钱黑产
浅谈黑客赚钱黑产
|
数据采集 人工智能 运维
智能化运维:AI在系统管理中的应用与挑战
【5月更文挑战第32天】随着人工智能技术的飞速发展,其在IT运维领域的应用正逐步改变传统的系统管理模式。本文将探讨AI技术如何优化运维流程、提高效率,并分析在实践中遇到的挑战和解决方案。
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp微信小程序的乡村政务服务系统的详细设计和实现
基于SpringBoot+Vue+uniapp微信小程序的乡村政务服务系统的详细设计和实现
206 1
|
小程序 JavaScript 安全
【微信小程序-原生开发】转发给好友/群,分享到朋友圈(含单页模式访问云开发数据库的方法)
【微信小程序-原生开发】转发给好友/群,分享到朋友圈(含单页模式访问云开发数据库的方法)
505 0
|
存储 安全 Java
Java数据类型 有这一篇就够(超详细!)
Java数据类型 有这一篇就够(超详细!)
455 0