问题
楼主碰到的问题是,在实体类和表中定义的某个字段为RMBPrice,首字母大写,sql查询出来的列名也是大写的RMBPrice,但是使用jquery的datatables初始化列时,却出错。
那一行的代码如下:
{"name": "RMBPrice", "data": "RMBPrice", "className": "text-center", "render": formatRMBPrice},
打开页面却会显示这个。查看浏览器调用接口返回的值:
是小写的rmbprice
分析
接口返回的是一个@ResponseBody对象,在代码中打断点,一直到接口的返回值都是大写的,所以只可能是转换到json的时候出了问题。
百度 json 首字母大写,就出现了自动转换为小写的文章。
经过测试确实是,当前几个都是大写的字母,都会转换成小写,直到不是大写为止,若小写后面还有大写,则保持大写。
如:RRRddRRR会变成rrrddRRR.
解决办法
我直接修改js里面那行代码,改为:
{"name": "rmbprice", "data": "rmbprice", "className": "text-center", "render": formatRMBPrice},
经过查询,如果要保留大写需要加上注解。
比如jackson使用:
在实体类定义字段时:
@JsonProperty("ActionCode") private String ActionCode = "";
fastjson使用:
@JSONField(name = “Name”) 而且该标记应该标记在get方法前:
public class User { private String name; private int age; @JSONField(name = "Name") public String getName(){ return name; } public void setName(String name){ this.name = name; } @JSONField(name = "Age") public int getAge(){ return age; } public void setAge(int age){ this.age= age; } }
也有说:
强制转换,用com.alibaba.fastjson.serializer.PascalNameFilter,直接把首字母转成大写。如:JSON.toJSONString(bean,new PascalNameFilter());
不过上面那些我都没有试过,因为我采用了自动转换为小写之后的name。想要保留大写还需要你们自己去多找找看喔~~??
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
在Vue 组件Toast中如何实现显示框效果
有关webpack中rules参数处理
在AngularJS中如何实现简单的计算
有关Bootstrap 模态框提交BUG的解决方案
在webpack中详细解读入口函数run
在Vue中如何实现进入/离开动画
在node.js中有关路由,中间件的详细介绍说明