版权声明:本文为楼主原创文章,未经楼主允许不得转载,如要转载请注明来源。
目前公司开发一直使用的是jeecg框架,简单好用,但有时候不如自己写的随心所欲。最近项目遇到一个需求, 想封装配置加解密,本来最开始的想法是通过entity的get,set方法,get时进行解密,set时进行加密。但是同事测试发现jeecg的datagrid展示时,会调用多次get方法,那么问题就来了,此方法就行不通了。
然后也有时间,我就查看了框架的源码,追踪到底发现它确实调用了多次,因为它在封装的时候,获取数据值需要调用,有查询条件它同样需要调用……既然此路不通,那么就换路吧。既然想配置,那就扩展标签。然后就开始挖源代码,源码面前,了无密码。最后发现其实并不是那么神秘。下面就扩展封装jeecg标签做个简单说明。
第一步:为你想扩展的标签起好名字
在easyui.tld里添加如下代码
1 <attribute> 2 <name>起个有意义的名字吧</name>//标签名称 3 <required>true</required>//是否必须 4 <rtexprvalue>true</rtexprvalue>//表示是否可以使用JSP表达式 5 <description>一看我就是好人</description>//描述 6 </attribute>
注意:如果你想在<t:datagrid>里使用该标签,那理所当然要将它放在<tag><name>datagrid</name><tag>这个tag里喽。
第二步:定义了,就要去为它声明
分别在DataGridColumnTag.java和DataGridColumn.java添加上定义,怎么定义?(protected boolean name;简单吧)然后生成get,set方法
第三步:开始使用,处理业务逻辑
在DataGridTag.java找到setColumn()方法,然后加上你添加的字段。在getField()方法里处理你的逻辑,比如,我定义了一个secret标签,然后如果secret为true,我就进行页面值解密处理。
1 //数据加密 2 if(column.isSecret()){ 3 sb.append(",formatter:function(value,rec,index){"); 4 5 sb.append("$.ajax({type: "post",url: "url", data: {"value":value}, dataType:"json",async : false,success: function(msg){value=msg.msg;} });return value;}"); 6 7 }
记得在DataGridColumnTag.java里doEndTag()方法里同样加上你定义的字段。ok,这样自定义标签已经封装完成,在页面里去使用吧。
<t:dgCol title="" field="" secret="true"></t:dgCol>