1,概要说明
创建枚举类,
在需要存储数据库的属性上添加@EnumValue注解,
在需要前端展示的属性上添加@JsonValue注解;
2,示例实践
public enum SexEnum {
MAN(1, "男"),
WOMAN(2, "女");
@EnumValue
private Integer key;
@JsonValue
private String display;
SexEnum(Integer key, String display) {
this.key = key;
this.display = display;
}
public Integer getKey() {
return key;
}
public String getDisplay() {
return display;
}
}
POJO中使用枚举类型标记字段
@ApiModelProperty(value = "性别")
private SexEnum sex;
测试使用
@Test
public void insert() {
UserInfo userInfo = new UserInfo();
userInfo.setAge(22);
userInfo.setName("李四");
userInfo.setSex(SexEnum.WOMAN);
userInfoMapper.insert(userInfo);
System.out.println(userInfo);
}
数据中存储的值是key
前端显示
[
{"id":"1","name":"张三","age":11,"sex":"男"},
{"id":"2","name":"李四","age":22,"sex":"女"},
{"id":"3","name":"王五","age":33,"sex":"男"}
]
以上内容原文链接:https://blog.csdn.net/linzhiji/article/details/109705536
3,几点思考
出现问题过程:
主要有2点原因:
1,前端的 sortable:true
排序有一个弊端,排序的逻辑顺序是先分页后排序,
但是这种逻辑在使用场景中是不合理的,所以这个属性仅仅适用于不分页的数据表格排序
2,由于使用@JsonValue
注解,返回给前端的数据是中文,
而中文的排序逻辑:计算机先将中文转换为Unicode编码(当然这个看你编码方式),
然后按照编码进行排序,这样排序出来的数据可能不如其愿。
建议:
开发后期前端有对枚举进行排序需求的话,建议不要使用该枚举,按照传统方式使用:
数据库中存储key值,同时传递给前端的值也是key值,由前端对key值做转换处理
引申:排序
1,前端排序代码(先分页后排序)
// todo
2,后端排序代码(先排序后分页)
// todo