Convert .Net object to JSON object in the view

后端 未结 3 1949
一整个雨季
一整个雨季 2020-12-24 07:26

I want to convert a .Net object in to JSON in the view. My view model is like this,

public class ViewModel{
    public SearchResult SearchResult { get; set;}         


        
相关标签:
3条回答
  • 2020-12-24 07:31

    This is an update to my original answer and I'll admit that as a result of the insistent badgering of @Tyrsius :D who refused to give up the fact that I could not access vars created in <script> tags in my MVC 5 cshtml page from my .js libraries in separate files, I discovered that if I placed the script tags inside of the @section scripts statement block that the vars created there did make the global scope and was available to my plugin widgets. I have not used it within any of my more complex apps as of yet, but did use it in a protoType of another app and the answer is below. Now @Html.Raw(...) works and I was able to serialize an object that I could immediately use.

    This is something I will be using from now on... thanks again for hanging in there with me @Tyrsius

       @section scripts
        {
        <script type="text/javascript">
            @using MRTCProtoType.Models.ControllerData.Contracts
    
            var testVar = @Html.Raw(JsonConvert.SerializeObject(WMMWorkloadTestData.getWorkloadTestData()));
        </script>
            @Scripts.Render("~/bundles/homeworkflow")
        }
    

    The following code is in a separate .js file

    $(document).ready(function() {  
        alert(JSON.stringify(testVar));
    });
    
    0 讨论(0)
  • 2020-12-24 07:47

    I use this helper since asp.net mvc 2

    public static MvcHtmlString ToJson(this HtmlHelper html, object obj)
    {
      JavaScriptSerializer serializer = new JavaScriptSerializer();
      return MvcHtmlString.Create(serializer.Serialize(obj));
    }
    
    public static MvcHtmlString ToJson(this HtmlHelper html, object obj, int recursionDepth)
    {
      JavaScriptSerializer serializer = new JavaScriptSerializer();
      serializer.RecursionLimit = recursionDepth;
      return MvcHtmlString.Create(serializer.Serialize(obj));
    }
    

    And in the view:

      <script>
        var s = @(Html.ToJson(Model.Content));
      </script>
    

    I should replace serializer with the JSON.Encode(..) now, like mentionned in the refer by Hemant. (It use itself JavaScriptSerializer).

    The source of your problem is the "@" which HTML encode the JSON. You can use @Html.Raw(..) to avoid this behavior.

    +: take a look for Json.Net http://json.codeplex.com/

    JSON.Net update

    I've updated the helper a while ago with JSON.net (much better).

    It seems some users continue to read, upvote and use the old code. I'd like they use a better way, with the new version below, or by using NGon like Matthew Nichols has noticed it in a comment.

    Here's the code:

    using System;
    using Newtonsoft.Json;
    
    namespace System.Web.Mvc
    {
      public static class HtmlHelperExtensions
      {
        private static readonly JsonSerializerSettings settings;
    
        static HtmlHelperExtensions()
        {
          settings = new JsonSerializerSettings();
          // CamelCase: "MyProperty" will become "myProperty"
          settings.ContractResolver = new Newtonsoft.Json.Serialization.CamelCasePropertyNamesContractResolver();
        }
    
        public static MvcHtmlString ToJson(this HtmlHelper html, object value)
        {
          return MvcHtmlString.Create(JsonConvert.SerializeObject(value, Formatting.None, settings));
        }
      }
    }
    
    0 讨论(0)
  • 2020-12-24 07:54

    Try using this method:

    @Html.Raw(Json.Encode(Model.Content))

    0 讨论(0)
提交回复
热议问题