0
ビューモデルをJSONに変換するために組み込みのASP.Net return JSON()
関数を使用しています。このビューモデルでプロパティの1つがdecimal
です。このプロパティが4.50
または4.00
のような値で埋められると、View ModelのJSONバージョンが末尾の0(s)を削除していることに気付きました。ビューでJavaScriptのデータを読み込むときにこの動作を停止すると、すべて0になります。ASP.Net JSONが小数点以下のプロパティの末尾に0を表示しないようにする
のViewModel:
public class TimeCardEntryVM
{
public int ID { get; set; }
public string ProjectCode { get; set; }
public string ProjectDescription { get; set; }
public string TaskCode { get; set; }
public string TaskDescription { get; set; }
public bool IsDurationTime { get; set; }
public decimal HoursWorked { get; set; }
public DateTime StartTime { get; set; }
public DateTime EndTime { get; set; }
public string WorkDescription { get; set; }
}
JSONを返すASP.Netコード:
{
var timeEntryData = db.TimeCards
.Include(timeCard => timeCard.Project)
.Include(timeCard => timeCard.Task)
.Where(timeCard => timeCard.ID == timeCardID)
.Select(timeCard => new TimeCardEntryVM()
{
ID = timeCard.ID,
EndTime = timeCard.EndDateTime,
ProjectCode = timeCard.Project.Code,
ProjectDescription = timeCard.Project.Description,
StartTime = timeCard.StartDateTime,
TaskCode = timeCard.Task.Code,
TaskDescription = timeCard.Task.Description,
HoursWorked = (decimal)timeCard.TimeWorked,
IsDurationTime = timeCard.IsDurationTime,
WorkDescription = timeCard.WorkDescription
}).First();
return Json(timeEntryData, JsonRequestBehavior.AllowGet);
}
私は値をチェックするために使用していたJavaScriptコード:
$.ajax({
type: "POST",
url: "/TimeCard/TimeCardEntry",
data: { timeCardID: args.row["uid"] },
success: function (data)
{
alert(data["HoursWorked"]);
}
});
私の検索ではそれを超えて実行されませんでしたが、多くの結果が得られませんでした。それはあなたに感謝しました。 – Matthew