javascript - 如何将 json 数据从 C# Controller 传递到 Angular js?

标签 javascript c# json asp.net-mvc angularjs

如何将 json 数据从 C# Controller 传递到 Angular js ?我想将 json 从 Controller 传递到 Angular js。我尝试了不同的方法,但没有一个有效。请参阅下面的代码,

var app = angular.module('myApp', []);
app.controller('customersCtrl', function ($scope, $http) {
    $http.get("/adnActions/getJson")
    .success(function (response) { alert(response.records); $scope.names = response.records; });
});

C# Controller 代码

 public async Task<string> getJson()
    {
                 data="{'records':[ {'Name':'Alfreds Futterkiste','City':'Berlin','Country':'Germany'}, {'Name':'Ana Trujillo Emparedados y helados','City':'México D.F.','Country':'Mexico'}]}";
       return data;    

    }

但无法获取 Angular JS Controller 中的数据 以下是控制台中引发的错误, “错误:JSON.parse:JSON 数据第 1 行第 2 列处的预期属性名称或“}”

如何解决这个问题?这里有什么问题吗?

最佳答案

我怀疑这是因为你的 JSON 的格式。您使用的是单引号还是双引号。有效的 JSON 使用 double quotes

这是我运行 json 时得到的结果,我已将响应更改为 HttpResponseMessage 并显式设置响应内容类型以消除此问题。根据您在 Javascript 方面的错误,我认为您的问题是 JSON 中的单引号。

    public async Task<HttpResponseMessage> GetJsonSingle()
    {
        HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK)
        {
            Content = new StringContent("{'records':[ {'Name':'Alfreds Futterkiste','City':'Berlin','Country':'Germany'}, {'Name':'Ana Trujillo Emparedados y helados','City':'México D.F.','Country':'Mexico'}]}")
        };

        result.Content.Headers.ContentType = new MediaTypeHeaderValue("application/json");

        return result;
        }

结果:

busted

双引号:

     public async Task<HttpResponseMessage> GetJsonDouble()
    {
        HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK)
        {
            Content = new StringContent("{\"records\":[ {\"Name\":\"Alfreds Futterkiste\",\"City\":\"Berlin\",\"Country\":\"Germany\"}, {\"Name\":\"Ana Trujillo Emparedados y helados\",\"City\":\"México D.F.\",\"Country\":\"Mexico\"}]}")
        };

        result.Content.Headers.ContentType = new MediaTypeHeaderValue("application/json");

        return result;
    }

工作正常:

correct

关于javascript - 如何将 json 数据从 C# Controller 传递到 Angular js?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31250029/

相关文章:

javascript - 在JS中获取多数组的值?

javascript - 停止冗余刷新 : JQuery

ios - NSURLConnection 在它应该之前调用 connectionDidFinishLoading?

javascript - 从 Angular 服务加载 JSON 数据

javascript - 如何处理 Promise 数组 then/catch

javascript - D3 JS代码分离

c# - 为过时的 C# 事件生成警告

php - 在 android 中获取 HTML 响应而不是 JSON

c# - 我如何将 Sevenzipsharp 与此代码一起使用?

C# 获取异步任务