首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >InvalidOperationException:传递给ViewDataDictionary的模型项是'System.Collections.Generics‘类型的--如何解决这个问题?

InvalidOperationException:传递给ViewDataDictionary的模型项是'System.Collections.Generics‘类型的--如何解决这个问题?
EN

Stack Overflow用户
提问于 2021-07-16 16:11:38
回答 1查看 1.6K关注 0票数 0

当我使用“视图”页面创建一个病人时,我遇到了这个问题:

'System.Collections.Generic.List`1PatientHut.Data.Models.Patient',InvalidOperationException:传递给ViewDataDictionary的模型项的类型是ViewDataDictionary,但是这个ViewDataDictionary实例需要一个'PatientHut.Data.Models.Patient‘类型的模型项。

我不知道如何解决我的问题,我已经试了好几个小时了。我相信这是一个简单的解决办法。

实际上,我只是意识到,当我试图运行时,视图中的所有页面都会出现相同的错误。我做错了什么?

代码语言:javascript
运行
复制
 My Model:

 namespace PatientHut.Data.Models
 {
 public enum Gender 
 {
    Male, Female
 }


 public class Patient
 {
    public int Id { get; set; }

    public string Name { get; set; }

    public Gender Gender { get; set; }

    public DateTime DateOfBirth { get; set; }

    public string EmailAddress { get; set; }

    public string PhoneNumber { get; set; }

    public string Address { get; set; }

    public int Age => (DateTime.Now - DateOfBirth).Days / 365;


    //EF Relationship - A Patient can have many bookings 

    public IList<AppointmentBooking> Bookings { get; set; } = new 
    List<AppointmentBooking>(); 
  
  }
  }

   My services: 


     public Patient AddPatient(Patient u) ///!!!!!!!!!!!!!! 
        //an Id to check(its new).
     {
        var existing = GetPatientByEmail(u.EmailAddress); //check if user has same email 
        address when creating a new user 

        if (existing != null)
        {
            return null;

            //if no user the same is found return null
        }

        {
            var user = new Patient //create new user object 
            {
                Name = u.Name,
                Gender = u.Gender,
                DateOfBirth = u.DateOfBirth,
                EmailAddress = u.EmailAddress,
                PhoneNumber = u.PhoneNumber,
                Address = u.Address,
                

            //Add users details
            };

            db.Patients.Add(user); // Add to the DB
            db.SaveChanges(); //SaveChanges to the DB

            return user; // returning new user 

        }
     }


  My controller


    public Patient AddPatient(Patient u) ///!!!!!!!!!!!!!! 
        //an Id to check(its new).
    {
        var existing = GetPatientByEmail(u.EmailAddress); //check if user has same email 
    address when creating a new user 

        if (existing != null)
        {
            return null;

            //if no user the same is found return null
        }

        {
            var user = new Patient //create new user object 
            {
                Name = u.Name,
                Gender = u.Gender,
                DateOfBirth = u.DateOfBirth,
                EmailAddress = u.EmailAddress,
                PhoneNumber = u.PhoneNumber,
                Address = u.Address,
                

            //Add users details
            };

            db.Patients.Add(user); // Add to the DB
            db.SaveChanges(); //SaveChanges to the DB

            return user; // returning new user 

        }
    }


 My view

 @model PatientHut.Data.Models.Patient

   @{
 ViewData["Title"] = "Create";
 }

 <h1>Create</h1>

 <h4>Patient</h4>
 <hr />
 <div class="row">
 <div class="col-md-4">
    <form asp-action="Create">
        <div asp-validation-summary="ModelOnly" class="text-danger"></div>
     
 
        <div class="form-group">
            <label asp-for="Name" class="control-label"></label>
            <input asp-for="Name" class="form-control" />
            <span asp-validation-for="Name" class="text-danger"></span>
        </div>
        <div class="form-group">
            <label asp-for="Gender" class="control-label"></label>
            <input asp-for="Gender" class="form-control" />
            <span asp-validation-for="Gender" class="text-danger"></span>
        </div>
        <div class="form-group">
            <label asp-for="DateOfBirth" class="control-label"></label>
            <input asp-for="DateOfBirth" class="form-control" />
            <span asp-validation-for="DateOfBirth" class="text-danger"></span>
        </div>
        <div class="form-group">
            <label asp-for="EmailAddress" class="control-label"></label>
            <input asp-for="EmailAddress" class="form-control" />
            <span asp-validation-for="EmailAddress" class="text-danger"></span>
        </div>
        <div class="form-group">
            <label asp-for="PhoneNumber" class="control-label"></label>
            <input asp-for="PhoneNumber" class="form-control" />
            <span asp-validation-for="PhoneNumber" class="text-danger"></span>
        </div>
        <div class="form-group">
            <label asp-for="Address" class="control-label"></label>
            <input asp-for="Address" class="form-control" />
            <span asp-validation-for="Address" class="text-danger"></span>
        </div>
        <div class="form-group">
            <input type="submit" value="Create" class="btn btn-primary" />
        </div>
    </form>
 </div>
 </div>

 <div>
 <a asp-action="Index">Back to List</a>
</div>

@section Scripts {
 @{await Html.RenderPartialAsync("_ValidationScriptsPartial");}
}
EN

回答 1

Stack Overflow用户

发布于 2021-07-16 18:36:34

你要把一个数组放进去。试着添加

代码语言:javascript
运行
复制
.FirstOrDefault(); 

在该错误被抛出之后。如果还没有,那么还需要在顶部添加一个"using System.Linq;“。

也就是说,如果您的代码在这里抛出一个错误(伪造代码,因为我看不到您的错误是从代码中抛出的):

代码语言:javascript
运行
复制
return patients;

将其切换到:

代码语言:javascript
运行
复制
return patients.FirstOrDefault();
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68412171

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档