现阶段的项目是采用前后端分离的思想,前端使用的是Angular.JS,后端使用ABP框架,在后端我们通过WebAPI技术来向前端提供json数据。以前是通过MVC来写前端的代码,感觉后端有点在控制前端的节奏,一些少量的后端代码还是需要在HTML页面中写的,这次采用的这种模式,前端不需要写一点后端的C#代码,只负责写自己页面,至于说后端,只需要提供统一的json格式数据就可以,不需要管我前端如何展示。就是这样的情况,下面我们来看下如何将后端的数据json化。
后端数据转换为json
假设前端需要如下的数据格式:那么我们后端提供的josn格式就应该是这样的,这就利用到数据格式的转换了。
那么我们定义相关的类,看如何实现这样的格式。
/// <summary> /// 第一大类 /// </summary> public class TreeView { [JsonProperty("id")] public int Id { get; set; } [JsonProperty("text")] public string Text { get; set; } [JsonProperty("children")] public IList<TreeChildrenView> Childrens{ get; set; } } /// <summary> /// 第一大类中包含的第二大类 /// </summary> public class TreeChildrenView { [JsonProperty("id")] public int Id { get; set; } [JsonProperty("text")] public string Text { get; set; } [JsonProperty("children")] public IList<Tree2ChildrenView> Childrens { get; set; } } /// <summary> /// 第二大类包含的第三大类 /// </summary> public class Tree2ChildrenView { [JsonProperty("id")] public int Id { get; set; } [JsonProperty("text")] public string Text { get; set; } }
我们后端需要进行josn化,就需要引用Newtonsoft.Json此类库。
JsonConvert.SerializeObject();
下面看我们的代码。
static void Main(string[] args) { var treeView = new TreeView() { Id=1, Text = "陕西", }; var childrenTree = new TreeChildrenView() { Id=2, Text = "宝鸡市" }; var chchTree = new Tree2ChildrenView() { Id=3, Text = "眉县" }; childrenTree.Childrens = new List<Tree2ChildrenView>(); childrenTree.Childrens.Add(chchTree); treeView.Childrens=new List<TreeChildrenView>(); treeView.Childrens.Add(childrenTree); string json = JsonConvert.SerializeObject(treeView); Console.WriteLine(json); Console.ReadLine(); }
我们可以看到只使用了一句转换代码。我们就可以得到具体的json数据。
解释
- 属性上面的标签 :[JsonProperty("id")]
意思是在json过程中将大写的Id转换为小写的。其余的意思一样。
- 实例化List<>
childrenTree.Childrens = new List<Tree2ChildrenView>();
难道我每次都要写这句吗。我们可以放到构造函数中去:
public class TreeView { public TreeView() { this.Childrens=new List<TreeChildrenView>(); } [JsonProperty("id")] public int Id { get; set; } [JsonProperty("text")] public string Text { get; set; } [JsonProperty("children")] public IList<TreeChildrenView> Childrens{ get; set; } }
这样我们每次就直接使用就OK了。
childrenTree.Childrens.Add(chchTree);
不需要再去实例化它,因为它自己调用的时候就自动实例化了。