'Do I have to manipulate the Model data in Controller to pass to View?
I have two tables: Cache (date (timestamp) and site) and SiteContent where I store words and their counts. One site has many SiteContents entries. I want to send SiteContents to View.
Cache:
[Required]
public string Site { get; set; }
[Required]
public DateTime Date { get; set; }
public virtual ICollection<Cash> SiteContent { get; set; }
SiteContent:
[Required]
public int CashId { get; set; }
public virtual Cache Site { get; set; }
[Required]
public string Word { get; set; }
[Required]
public uint Count { get; set; }
Code of controller:
public IActionResult Index()
{
//Console.WriteLine(_context.Caches.ToArray()[0].Site);
//Console.WriteLine(_context.SiteContents.ToArray()[0].Word);
//Console.WriteLine(_context.SiteContents.ToArray()[0].Site.Site);
return View(_context.SiteContents.ToList());
}
View code:
@using ParserWeb.Models
@model IEnumerable<SiteContent>
@{
ViewData["Title"] = "Home Page";
}
<table class="table">
@foreach (SiteContent c in Model)
{
<tr> <td>@c.Site.Date</td> <td>@c.Site.Site</td> <td>@c.Word</td> <td>@c.Count</td> </tr>
}
</table>
How come the code only works if I uncomment? Otherwise there is
System.NullReferenceException: "Object reference not set to an instance of an object."
Solution 1:[1]
@foreach (SiteContent c in Model)
{
<tr> <td>@c.Site.Date</td> <td>@c.Site.Site</td> <td>@c.Word</td> <td>@c.Count</td> </tr>
}
You wanna use @c.Site.Date
but you don't include Site
.
Site = null
and you wanna use Site.Date, (property of null) that's the reason of exception.
Answer:
return View(_context.SiteContents.Include(s => s.Site).ToList());
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
Solution | Source |
---|---|
Solution 1 |