开发者

issue with kendogrid using postgresql

开发者 https://www.devze.com 2022-12-07 18:13 出处:网络
I am sending json data but not able to fill json data in kendoUI and postgre I am trying to populate the kendo grid with the JSON data received from the controller but failing

I am sending json data but not able to fill json data in kendoUI and postgre

I am trying to populate the kendo grid with the JSON data received from the controller but failing

issue with kendogrid not able to fill the data in kendogrid

I am send the json data but not fill in kendogrid

I am trying to populate this kendo grid but I am running into some issues.

HomeController.cs


        public ActionResult Index()
        {
            return View();
        }

        //read data from database
        [HttpGet]
        public ActionResult getAlbum()
        {
            DataSet ds = new DataSet();
            string queryString = "SELECT albumid,album_art, genre,title, artist,price FROM public.adalbum;";

            NpgsqlCommand command = new NpgsqlCommand(queryString, conn);

            command.Connection = conn;
            using (NpgsqlDataAdapter sda = new NpgsqlDataAdapter(command))
            {
                sda.Fill(ds);
            }
            List<Album> album = new List<Album>();

            var result = new { album = ds };
            string json = JsonConvert.SerializeObject(result, Formatting.Indented,new JsonSerializerSettings {
                ReferenceLoopHandling = ReferenceLoopHandling.Ignore
                            });
            //return Json(result, "Album", JsonRequestBehavior.AllowGet);
            //return Json(ds, JsonRequestBehavior.AllowGet);
            //return result;
            //var jsonSerializer = new System.Web.Script.Serialization.JavaScriptSerializer();

            //List<Album> lstDept = album.Select(d => new Album()
            //{
            //    albumid = d.albumid,
            //    album_art = d.album_art,
            //    genre = d.album_art,
            //    title = d.title,
            //    artist = d.artist,
            //    price = d.price
            //}).ToList();

            //string json = jsonSerializer.Serialize(lstDept);

            return Json(json);

        }

Index.cshtml

@{
    ViewBag.Title = "Home Page";
}

<div class="jumbotron">
    <label></label>
</div>

<div id="maingrid"></div>

<script src="~/Scripts/jquery-1.10.2.min.js"></script>
<link rel="stylesheet" href="https://kendo.cdn.telerik.com/2022.3.1109/styles/kendo.default-main.min.css">
<script src="https://kendo.cdn.telerik.com/2022.3.1109/mjs/kendo.grid.js" type="module">
</script>
<script src="https://kendo.cdn.telerik.com/2022.3.1109/js/kendo.all.min.js"></script>

<script type="text/javascript">
    $(document).ready(function () {
        //var gridDataSource = new kendo.data.DataSource({
        //    //  data: [{ 开发者_StackOverflow"album_art": "asd", "genre": "asdasd", "artist": "asdasd", "title": "asdasd", "price": 0}],
        //    transport: {
        //        read: {
        //            url: "/Home/getAlbum",
        //            type: "GET",
        //            data: {
        //                tags: "nature",
        //                format: "json"
        //            },
        //            dataType: "jsonp",
        //            jsonp: "jsoncallback",
        //        }
        //    },
        //});
        //dataSource: gridDataSource,
        var dataSource = new kendo.data.DataSource({
            transport: {
                read: {
                    url: "/Home/getAlbum",
                    type: 'GET',
                    data: {
                        //tags: "nature",
                        format: "json"
                    },
                    dataType: "json", // "jsonp" is required for cross-domain requests; use "json" for same-domain requests
                    jsonp: "jsoncallback",
                    contentType: 'application/json',
                }
            },
            pageSize: 10,
            batch: false,
            schema: {
                data: "Table",
                model: {
                    id:"albumid",
                    fields: {
                        albumid: { editable: false, nullable: true },
                        album_art: { type: "string" },
                        genre: { type: "string" },
                        title: { type: "string" },
                        artist: { type: "string" },
                        price: { type: "number" },
                    }
                }
            },
        });
        console.log(dataSource);
        $('#maingrid').kendoGrid({
            dataSource: dataSource,
            toolbar: ("<a href=@Url.Action("CreateAlbum", "Home")>Create Album</a>"),
            //sortable: true,
            pageable: true,
            editable: "inline",
            columns: [
                { field: "albumid", title: "Album ID", width: 50 },
                { field: "album_art", title: "Album Art", width: 50 },
                { field: "genre", title: "Genre", width: 50 },
                { field: "title", title: "Title", width: 50 },
                { field: "artist", title: "Artist", width: 50 },
                { field: "price", title: "Price", width: 50 }
            ],
        });

    });
</script>

my jsn response from controller side

{
  "album": {
    "Table": [
      {
        "albumid": 1,
        "album_art": "Screenshot (2).png",
        "genre": "Rock",
        "title": "test",
        "artist": "A KB",
        "price": null
      },
      {
        "albumid": 2,
        "album_art": "Screenshot (1).png",
        "genre": "Rock",
        "title": "test",
        "artist": "Numbi",
        "price": 2000.0
      }
    ]
  }
}

need help I tried but not able to fill the data

0

精彩评论

暂无评论...
验证码 换一张
取 消