afagh Ответов: 1

Jsonrequestbehavior.allowget не существует в текущем контексте


I am using asp.net MVC core and I am going to read data from SQL in kendo drop-down list. I have installed Newtonsoft.Json library too. I see drop-down list but I can't load data in my drop-down list. my code is as below:

What I have tried:

<pre>my model is located in models>Airports.cs:


using System;
using System.Collections.Generic;
using System.Threading.Tasks;

namespace plan_1.Models
{
public class Airport: BaseEntity  
   { 
    public int Id { get; set; }
    public string Iata { get; set; }
    public string Icao { get; set; }
    public string LogoUrl { get; set; }
    public int IsBased { get; set; }
    public int CityId { get; set; }
    public virtual City City { get; set; }

    public Airport()
    {
        this.Terminals = new 
          HashSet<Terminal>();
    }
     public ICollection<Terminal> Terminals 
     { get; set; }
   }
}


My controller is located in Controllers>planController.cs :


using System.Linq;
using Microsoft.AspNetCore.Mvc;
using plan_1.Models;
namespace plan_1.Controllers
{
 public class planController : Controller
 {        
    public ActionResult Index()
    {
        return View();
    }
    public JsonResult GetAirPort()
    {
      plan_1Context dbContext = new 
      plan_1Context();

        return 
        Json(dbContext.AirPorts.Select(O => 
        new { _Id = O.Id, Origin = O.Iata 
        }), 
     JsonRequestBehavior.AllowGet);
    }
  }
}


and my view located in views>plan>index.cshtml is as below:


@model IEnumerable<plan_1.Models.Airport>
@{
 ViewData["Title"] = "Planing";
 }

 <div>
    <h4>Origin:</h4>
    @(Html.Kendo().DropDownList()
                .Name("Origin")
                .HtmlAttributes(new { style 
    = "width:100%" })
                .OptionLabel("Select 
     category...")
                .DataTextField("Iata")
                .DataValueField("Id")
                .DataSource(source =>
                {
                    source.Read(read =>
                    {                  
read.Action("GetAirPorts", 
       "planController");
                    });
                })
    )
</div>
also, I should mix the airplane model by 
the plan model, I think I should use the 
view model to mix them.

Please help what should I do? It is days 
that I am looking for the answer

1 Ответов

Рейтинг:
0

Bohdan Stupak

Это нормально не использовать JsonRequestBehavior.AllowGet больше не.
Просто использовать

return Json(dbContext.AirPorts
	.Select(O => new { _Id = O.Id, Origin = O.Iata}));

вместо.
И да, это нормально-смешивать модели внутри моделей просмотра.


afagh

привет, Богдан, я уже делал это раньше, но моя страница пустеет, а другие элементы не отображаются

Bohdan Stupak

Но бэкэнд возвращает элементы правильно, не так ли? Это клиент неправильно обращается с ними?