更新 : 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