优化类型填充

This commit is contained in:
白茶清欢 2023-02-02 10:52:40 +08:00
parent 10854957c0
commit 1e0c756917

View File

@ -71,11 +71,11 @@ func (rt *ReflectType) Do(dataFlag string, data interface{}) *StructInfo {
field := &StructField{ field := &StructField{
Idx: idx, Idx: idx,
Name: reflectType.Field(idx).Name, Name: reflectType.Field(idx).Name,
Type: reflectType.Field(idx).Type.Kind(),
JsonTag: reflectType.Field(idx).Tag.Get(JsonTag), JsonTag: reflectType.Field(idx).Tag.Get(JsonTag),
EventTag: reflectType.Field(idx).Tag.Get(OutEventTag), EventTag: reflectType.Field(idx).Tag.Get(OutEventTag),
MappingRuleList: make([]MappingRuleItem, 0), MappingRuleList: make([]MappingRuleItem, 0),
} }
rt.fillFieldType(field, reflectType.Field(idx).Type.Kind())
rt.fillMappingRule(field, reflectType.Field(idx).Tag.Get(MappingTag)) rt.fillMappingRule(field, reflectType.Field(idx).Tag.Get(MappingTag))
res.StructFieldList = append(res.StructFieldList, field) res.StructFieldList = append(res.StructFieldList, field)
} }
@ -83,6 +83,28 @@ func (rt *ReflectType) Do(dataFlag string, data interface{}) *StructInfo {
return res return res
} }
// fillFieldType 填充字段类型
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 20:46 2023/2/1
func (rt *ReflectType) fillFieldType(field *StructField, dataType reflect.Kind) {
switch dataType {
case reflect.Float32:
fallthrough
case reflect.Float64:
field.Type = reflect.Float64
case reflect.String:
field.Type = reflect.String
default:
if strings.Contains(dataType.String(), "int") {
field.Type = reflect.Int64
} else {
field.Type = reflect.Interface
}
}
}
// fillTagInfo 填充标签信息 // fillTagInfo 填充标签信息
// //
// Author : go_developer@163.com<白茶清欢> // Author : go_developer@163.com<白茶清欢>