Asp.net core Enum as string + ef core value convertor

更新 : 2019-06-08 前端

build in convertor web

https://docs.microsoft.com/en-us/ef/core/modeling/value-conversions#built-in-converterssql

注意 : value null 是不走 convertor 的哦, 因此咱们也不须要顾虑 nullable 的状况.typescript

 

更新 2019-06-01 数据库

string jsonWithConverter = JsonConvert.SerializeObject(new Dada { name = "keatkeat", type = Type.Completed }, new StringEnumConverter());

 

 

写 c# 咱们喜欢用 enum. 可是 enum to sql, enum to fronend 都是麻烦. json

由于 enum 通常会转换成 int 而不是 string. 但是这样就不可读了. c#

因此呢,咱们的要动点手脚 api

 

ef core convert asp.net

modelBuilder.Entity<Order>().Property(p => p.status).IsRequired().HasMaxLength(128).HasConversion(
    v => v.ToString(),
    v => (OrderStatus)Enum.Parse(typeof(OrderStatus), v)
);

有了这个在数据库就能够看见 string 了.ui

 

而后是 web api 

services.AddMvc(options =>
{
    options.EnableEndpointRouting = false;
})
.AddJsonOptions(options =>
{
    options.SerializerSettings.Converters.Add(new StringEnumConverter());
})

这样 GET 就能够输出 string 了,  POST 的时候 binding, asp.net core 会自动转换, 因此前端传 string or int 均可以. 

 

OData

很是聪明,啥也不用弄,它原本就输出 string ... 也有点恐怖啦..

 

typescript 

enum StringStatus { 
    pending = 'pending',
    completed = 'completed'
}
enum NumberStatus { 
    pending,
    completed = 13
}
console.log(StringStatus.pending); // 'pending'
console.log(NumberStatus.pending); // 0
console.log(NumberStatus.completed); // 13
相关文章
相关标签/搜索