自定义字段的设计与实现(Java实用版)

  1. 前言

    自定义字段又叫做“开放模型”,用户可以根据自已的需求,添加需要的字段,实现个性化定制。

  2. 使用自定义字段的目的,使用自定义字段解决哪些问题

    如现有一套CRM系统,客户模块中客户信息,需要实现不同行业,不同业态都可以个性化需求。那我们知道客户信息表T_CUSTOM,如姓名,性别,电话

    等基本通用属性是可以通用的,但如药疗行业客户需要记录体重,血压等,而运输行业的客户更关注货物品类,产量等,而又如快速消费品行业关注客户的爱好,年龄,星座啊,这些问题该如何处理呢?

  3. 自定义字段的设计与实现

    a、相关数据库表说明

    自定义模板表:T_CUSTOM_FIELD_TEMPLATE

    客户信息表:T_CUSTOM

    业态行业类型与自定模板对应用表:T_BUSINISS_TEMPLATE

    注:T_BUSINISS_TEMPLATE不同的业态、行业类型对应不同的自定义模板

    b、相关数据库表结构说明
    
    
    
    • 1

    自定义模板表:T_CUSTOM_FIELD_TEMPLATE

注:模板内容如下

[{"label":"货品名称","fieldName":"productName","type":"textfield","required":true,"sequence":1,"rows":3,"minLength":5,"maxLength":20,"vtype":"none","vtypeContent":"","vtypeText":"","defaultValue":"apple Mac","readOnly":false},{"label":"产量","fieldName":"turnout","type":"numberfield","required":true,"sequence":2,"minValue":5,"maxValue":20,"decimalPrecision":2,"defaultValue":20000,"readOnly":false},{"label":"爱好","fieldName":"loves","type":"combobox","required":false,"sequence":4,"singleOption":[{"itemValue":"1","itemName":"看书"},{"itemValue":"2","itemName":"羽毛球"}],"defaultValue":"1"}]

运输行业扩展模板

自定义字段的类型有,文本框、数字框、日期框、单选框、多选框

新增文本框类型的自定义字段

新增数字框类型的自定义字段

新增日期框类型的自定义字段

新增单选框框类型的自定义字段

新增多选框类型的自定义字段的界面可以参考单选框界面。

看到这里,有一定基础的同志们肯定会有豁然开朗的感觉。

数据库表中数据如下:

医疗行业新增用户界面

快消行业新增用户界面

运输行业新增用户界面

点新增客户按钮后,会根据用当前的不同业态自动加载不同的自定义模板,在界面显示不同的业务自定义字段。

d、涉及相关知识点的剖析和处理

? 新增不同的自定义字段保存到自定义模板中

//获取post请求的所有参数以及参数对应的值
   Map<String, String[]> params = request.getParameterMap();
            JSONObject jsonObject = new JSONObject();
            for (String key : params.keySet()) {
                String[] values = params.get(key);
                for (int i = 0; i < values.length; i++) {
                    String value = values[i];
                    jsonObject.put(key, value);
                }
            }
            String content = jsonObject.toString();

用上面的代码,新增不同的自定义字段在后台就可以统一处理了,然后将自定义字段的JSON拼装起来。

? 新增用户时,在后台获取到模板内容,扩展字段怎么显示在前台新增页面。

后台代码如下:

String content = customFieldTemplate.getContent();
request.setAttribute("content", content);

在页面动态加载自定义模板,页面代码如下:

<div id="customFieldDiv" class="easyui-panel" title="自定义字段"
                  style="width:96%;height:200px;padding:5px;">
            </div>

var dataStr = ‘${content}‘;

        var jsondatas=eval("("+dataStr+")");
        var resultHtml = "";
        $.each(jsondatas,function(i,n){
            if(n.sequence == (i + 1)){
                resultHtml = resultHtml + ‘<table class="table" style="width: 100%;">‘;
                if(n.type == ‘textfield‘){
                    resultHtml = resultHtml + ‘<tr><td><input labelAlign="right" labelWidth="100px;" label="‘+n.label+‘" style="width:300px;" type="text" name="‘+n.fieldName+‘" value="‘+n.defaultValue+‘" class="easyui-textbox" data-options="required:‘+n.required+‘"/></td></tr>‘;
                }else if(n.type == ‘numberfield‘){
                    resultHtml = resultHtml + ‘<tr><td><input labelAlign="right" labelWidth="100px;" label="‘+n.label+‘" style="width:300px;" type="text" name="‘+n.fieldName+‘" value="‘+n.defaultValue+‘" class="easyui-numberbox" data-options="required:‘+n.required+‘,min:‘+n.minValue+‘,precision:‘+n.decimalPrecision+‘"/></td></tr>‘;
                }else if(n.type == ‘datetime‘){
                    resultHtml = resultHtml + ‘<tr><td><input labelAlign="right" labelWidth="100px;" label="‘+n.label+‘" style="width:300px;" type="text" name="‘+n.fieldName+‘" value="‘+n.defaultValue+‘" class="easyui-datebox" data-options="required:‘+n.required+‘,min:‘+n.minValue+‘"/></td></tr>‘;
                }else if(n.type == ‘combobox‘){
                    resultHtml = resultHtml + ‘<tr><td><select labelAlign="right" labelWidth="100px;" label="‘+n.label+‘" style="width:300px;"  name="‘+n.fieldName+‘" class="easyui-combobox" data-options="required:‘+n.required+‘">‘;
                    $.each(n.singleOption,function(j,m){
                        resultHtml = resultHtml + ‘<option value="‘+m.itemValue+‘">‘+m.itemName+‘</option>‘;
                    });
                    resultHtml = resultHtml + ‘</select>‘;
                    resultHtml = resultHtml + ‘</td></tr>‘;
                }

                resultHtml = resultHtml + ‘</table>‘;
            }
        });
        $(‘#customFieldDiv‘).append(resultHtml);

  1. 小结

    自定义字段的另一种解决方案EAV(Entity-Attribute-Value),大家可以百度。

    自定义模板内容和客户表中的护展字段模板数据都是大文本类型(longtext), mysql5.7 支持json,可以将这两个字段改为json类型。另外hibernate映射数据库中的json字段解决方案可以参考http://blog.csdn.net/qian_meng/article/details/48394379。通过上面两点可以对系统进行进一步的优化。

    自定义字段的类型,除文本框、数字框、日期框、单选框、多选框外还可以添加图片、声音、视频等其他类型。

    自定义字段数量很多时,又类型不同,怎样布局,使用页面更美观、舒服也有一定难度。

原文地址:https://blog.csdn.net/ytangdigl/article/details/70145910

原文地址:https://www.cnblogs.com/jpfss/p/11692278.html

时间: 2024-10-30 03:48:28

自定义字段的设计与实现(Java实用版)的相关文章

EVA:自定义字段实现

原文链接:http://blog.csdn.net/ytangdigl/article/details/70145910 前言 自定义字段又叫做"开放模型",用户可以根据自已的需求,添加需要的字段,实现个性化定制. 使用自定义字段的目的,使用自定义字段解决哪些问题 如现有一套CRM系统,客户模块中客户信息,需要实现不同行业,不同业态都可以个性化需求.那我们知道客户信息表T_CUSTOM,如姓名,性别,电话 等基本通用属性是可以通用的,但如药疗行业客户需要记录体重,血压等,而运输行业的客

模块管理常规功能自定义系统的设计与实现(52--功能更新[2] 对百分比字段的操作)

功能更新(2)  对百分比字段的操作 百分比数据,或者是比率数据是一个比较难处理的字段,难点并不在于单条记录之中,而是在于汇总和分类汇总的时候. 先来看看我系统中的一个模块中的一个比率字段: 上图中的  已支付比例,这个字段是  已支付金额 / 结算金额,这个字段在此合同模块中可以作为一个计算字段来保存在数据库中,甚至可以不保存在数据库中,直接在bean里作为一个计算的属性. 现在问题就来了,如果要计算所有合同的已支付比例,那么就不是简单加起来的问题了,要把分子和分母分别加起来再除才会得到总计的

JIRA Rest JAVA Client API实现问题管理及自定义字段

JIRA是一个缺陷跟踪管理系统,被广泛应用于缺陷跟踪.客户服务.需求收集.流程审批.任务跟踪.项目跟踪和敏捷管理等工作领域,当我们需要把第三方业务系统集成进来时,可以调用他的API. JIRA本身的API非常强大,但它是一个底层的API体系,并不是一个易用的接口,如果要开发和拓展,所以需要我们二次包装. jira官方为解决这个问题,推出了方便强大的java client library(目前只有java客户端库,没有.Net类库) jira的Rest API  最新文档官网. JIRA 6.4.

项目开发中自定义字段设计原则

在开发系统过程中,做到自定义字段策略设置,目前这种功能是很多系统的标准配置,这样子可以简化后续增加字段的难度,并对自定义字段做管理. 自定义字段功能要注意到以下几点: 1.批量规划好要自定义字段的数据表.2.对自定义字段存放的表字典表做设计3.对自定义字段做不同的属性设计4.自定义字段的扩展设计 1.明确是哪个表需要自定义字段.如果是开发一套易用的系统,做开发的时候对用到的主表做统一的自定义字段设计.这样子方便在以后的开发应用中直接操作自定义功能就能增加字段.很多程序员在初写程序的时候,增加字段

模块管理常规功能自定义系统的设计与实现(22--第二个模块的加入)

模块"市"的设计与加入 现在重复加入"省"模块的过程,来加入市的模块. 1.建立数据表City CREATE TABLE [dbo].[City]( [tf_cityId] [nvarchar](4) COLLATE Chinese_PRC_CI_AS NOT NULL, [tf_provinceId] [nvarchar](2) COLLATE Chinese_PRC_CI_AS NOT NULL, [tf_name] [nvarchar](50) COLLATE

模块管理常规功能自定义系统的设计与实现(12--Grid导航设计初步[2])

Grid导航设计初步[2] 上一节介绍了一个字符串字段和一个Boolean字段的导航设置,这一节更进一步,对日期字段的导航进行一下设计. 对于一个日期字段,可以想到的导航是:按年度,年度季度,年度月度,年月日,并且可以正序和倒序.下面还是以省份"这个模块为例看看日期导航.在"省份"模块中,我加入了一个字段"附加日期",这个字段的值是无任何意义的,放在那里只是为了现在用它来进行导航的演示. 按上一节的方法,将"附加日期"的可导航,打勾后,

模块管理常规功能自定义系统的设计与实现(30--第二阶段总结)

第二阶段总结 经过了前二个阶段近30节介绍,一个完全基于前台配置的销售管理系统即架构成功,并可以使用.当然实际的需求还是千变万化,五花八门,但只要是符合关系数据库原理,只要是以记录作为管理的主体,那就只是一个字段和表扩充的过程了.在搭建系统整个过程中模块采用了自顶向下生成的方式.对于层次多,关系复杂的系统也是一样的,设计合理,逻辑清楚,模块只要一个个搭就行了.开发好以后,整个系统的开发文档其实也在里面了,所有模块的属性,字段的属性,各模块之间的关系,都可以在这个系统里看得见了. 至于开发速度也是

模块管理常规功能自定义系统的设计与实现(36--终级阶段 综合查询[3])

综合查询(3)--查询条件的设置2 不仅仅对于模块才有这样方便的条件选择方式,对模块的字段也可以设置.例如对于"省份"中有个字段是"所属区域",这个字段不是一个manyToOne字段,而是一个字符串字段,里面就是存着"东北地区"."华北地区"等等这样的具体的字符串值.对于这样的字段也很容易将其放在toolbar上供选择.在模块字段中找到"所属区域"这个字段,修改字段的属性,让这个字段可以加到综合查询的too

模块管理常规功能自定义系统的设计与实现(33--权限设计[3])

权限设计(3) 三.字段的只读权限.对于可以修改记录的操作员,可以进一步限制哪些字段对于他是不可修改的.这个功能很少用到,是用户提出来的,我就顺便加了进去.实现这个功能也很简单建立只读字段角色,然后加入模块的字段,最后再将角色加到操作员上即可.前台在解释生成edit form 的时候,将这个字段的只读属性置为true即可.后台Hibernate在新增或保存的时候,可以把只读字段过滤掉,不能保存或不能修改即可. 四.字段的可视权限.有时候某些字段你不希望被某些群组的操作员看到,那么就设置一个隐藏字