zoukankan      html  css  js  c++  java
  • .NET模型序列化json数据[转] cow

    转换采用微软.net类库中的 JavaScriptSerializer 类来完成。


    序列号所用数据模型定义
    复制  保存
    public class Study
    {
        public string Name { get; set; }
        public int Age { get; set; }
    }


    将后台模型转换成json字符串的方法有以下几种:

    1、直接将数据序列化为json字符串
    复制  保存
    Study study = new Study() { Name = "你好", Age = 22 };

    JavaScriptSerializer serialize = new JavaScriptSerializer();
    string result = serialize.Serialize(study);

    结果:{"Name":"你好","Age":22}

    2、采用匿名对象自定义数据对象的序列化
    复制  保存
    Study study = new Study() { Name = "你好", Age = 22 };

            JavaScriptSerializer serialize = new JavaScriptSerializer();
            string result = serialize.Serialize(new { N = study.Name, A = study.Age });

    结果:{"N":"你好","A":22}

    3、继承JavaScriptConverter类,实现自定义数据对象的序列化
    复制  保存
    using System.Collections.Generic;
    using System.Collections.ObjectModel;
    using System.Web.Script.Serialization;
    public class StudyJsonConverter : JavaScriptConverter
    {
        public override object Deserialize(IDictionary<string, object> dictionary, Type type,
            JavaScriptSerializer serializer)
        {
            if (dictionary == null)
                return null;
            if (type == typeof(Study))
            {
                Study result = new Study();
                result.Name = dictionary["N"] as string;
                result.Age = Convert.ToInt32(dictionary["A"]);
                return result;
            }
            return null;
        }


        public override IDictionary<string, object> Serialize(object obj, JavaScriptSerializer serializer)
        {
            Study study = obj as Study;
            Dictionary<string, object> result = new Dictionary<string, object>();
            if (study != null)
            {
                result.Add("N", study.Name);
                result.Add("A", study.Age);
            }
            return result;
        }


        public override IEnumerable<Type> SupportedTypes
        {
            get { return new ReadOnlyCollection<Type>(new List<Type>() { typeof(Study) }); }
        }
    }

    序列化对象
    复制  保存
    Study study = new Study() { Name = "你好", Age = 22 };

    JavaScriptSerializer serialize = new JavaScriptSerializer();
    serialize.RegisterConverters(new List<JavaScriptConverter>() { new StudyJsonConverter() });
    string result = serialize.Serialize(study);

    结果:{"N":"你好","A":22}


    几种结果的比较

    第一种序列化的方法最简单,却有问题最大。当后太数据模型发生变化时,就会影响到前台的JavaScript脚本,前台和后台的的连接过于紧密。并且不能对数据模型的属进行压缩。

    第二种和第三种可对数据模型的属性进行压缩,并且后台模型发生改变,也不会影响到前台的JavaScript脚本。在应用时根据情况来采用采用不同的方法。

  • 相关阅读:
    vue 高度 动态更新计算 calcHeight watch $route
    vue 自定义组件 v-model双向绑定、 父子组件同步通信【转】
    vue 异步请求数据后,用v-if,显示组件,这样初始化的值就在开始的时候传进去了
    vue $parent 的上一级 有可能不是父组件,需要好几层$parent 如果这样 还不如用 this.$emit
    vue render {} 对象 说明文档
    params.row[params.column.key] vue h函数 当前单元格 h函数 div 属性 值或数组 render
    upload 上传按钮组件 iview
    下拉列表事件 Dropdown iview
    this.treeData = JSON.parse(JSON.stringify(this.d)) 树的序列化反序列化
    tree iview treeData json数据 添加 selected 数据 要进行vue.set 进行响应式添加
  • 原文地址:https://www.cnblogs.com/cowman/p/1847585.html
Copyright © 2011-2022 走看看