激情欧美一区二区三区|人妻超清中文乱码一区|你懂的在线视频中文字幕|青青青国产免A在线观看|日本成本人片免费播放网站|久久无码爆乳一区二区三区|国产成人精品999在线观看|欧美精品一区二区视频在线播放

前后端交互,在前端獲取長整型數據精度丟失問題

發(fā)布于: 2024-09-27    瀏覽: 1168    作者:四號員工

1. 問題描述

描述:在前端訪問到后端接口的過程中,Long類型數據精度,末尾三位數被歸零

1.1.后端

1.1.1.后端數據類型

 /// <summary>  

 /// 表單類型  

 /// </summary>  

 public class FormType  

 {  

     /// <summary>  

     /// 類型編號  

     /// </summary>  

     public long TypeID { get; set; }  

     /// <summary>  

     /// 類型編碼  

     /// </summary>  

     public string TypeCode { get; set; }  

     /// <summary>  

     /// 類型名稱  

     /// </summary>  

     public string TypeName { get; set; }  

     /// <summary>  

     /// 創(chuàng)建時間  

     /// </summary>  

     public DateTime CreateTime { get; set; }  

 }  

 

1.1.2.后端接口

 public class FormTypeController : ApiController  

 {  

     /// <summary>  

     /// 獲取表單類型集合  

     /// </summary>  

     /// <returns></returns>  

     public IHttpActionResult GetFormTypes()  

     {  

         List<FormType> formTypes = new List<FormType>();  

         formTypes.Add(new FormType { TypeID = 8484382934839484333, TypeCode = "tps", TypeName = "尿液基蒲層細胞檢測申請單", CreateTime = DateTime.Now });  

         formTypes.Add(new FormType { TypeID = 8484382934839484334, TypeCode = "tct", TypeName = "液基薄層細胞學檢測申請單", CreateTime = DateTime.Now });  

         return Json<List<FormType>>(formTypes);  

     }  

 }  


1.2.前端

1.2.1.前端訪問

 <script src="javascript/jquery/jquery.js"></script>  

 <script>  

     $(function () {  

         $.get(  

             "http://localhost:54809/api/FormType/GetFormTypes",  

             "",  

             function (data) {  

                 console.log(data);  

             },  

             "json"  

         )  

     })  

 </script> 


1.2.2.前端訪問結果



2.問題分析

在前后端數據交互的過程中,長整型(long)數據類型被轉換為了 JavaScript 中的 Number 類型,由于 JavaScript 中的 Number 類型采用的是 IEEE 754 標準的雙精度浮點數表示法,使用 64 位二進制格式存儲數字,其中 1 位符號位、11 位指數位和 52 位尾數位。因此,JavaScript 中的 Number 類型能夠存儲的有效數字位數為 52 位,即最多可以精確表示 15 位十進制數字。

Javascript Number類型范圍 -9007199254740991 到 9007199254740991

C# long類型范圍 -9,223,372,036,854,775,808 到 9,223,372,036,854,775,807


3.問題解決

思路:前后端數據交互式,將Long數據轉換為字符串

3.1.添加一個用于在json序列化時將long類型轉換為string類型的類

 public class LongToStringConverter : JsonConverter  

 {  

     public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)  

     {  

         try  

         {  

             return reader.Value.ToString();//.ObjToLong();  

         }  

         catch (Exception ex)  

         {  

             throw ex;  

         }  

     }  

   

     public override bool CanConvert(Type objectType)  

     {  

         return true;  

     }  

   

     public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)  

     {  

         if (value == null)  

         {  

             writer.WriteNull();  

             return;  

         }  

         string sValue = value.ToString();  

         writer.WriteValue(sValue);  

     }  

 }  


3.2.將該類添加在實體對應的屬性之前

 /// <summary>  

 /// 表單類型  

 /// </summary>  

 public class FormType  

 {  

     /// <summary>  

     /// 類型編號  

     /// </summary>  

     [JsonConverter(typeof(LongToStringConverter))]  

     public long TypeID { get; set; }  

     /// <summary>  

     /// 類型編碼  

     /// </summary>  

     public string TypeCode { get; set; }  

     /// <summary>  

     /// 類型名稱  

     /// </summary>  

     public string TypeName { get; set; }  

     /// <summary>  

     /// 創(chuàng)建時間  

     /// </summary>  

     public DateTime CreateTime { get; set; }  

 }  


3.3.前端訪問結果

在線客服

售前咨詢

售后服務

投訴/建議

服務熱線
0731-83091505
18874148081