错误:值不能为null。参数名称:来源

时间:2020-04-10 20:41:22

标签: asp.net-mvc entity-framework

我是编程新手,我正在尝试创建一个购物网站,就像用户出售其产品一样。

我有产品和用户表。产品表中有一个“ userId”列,该列由用户表中的“ ID”引用。只有登录的用户可以添加产品,我想在他们添加的每个用户的个人资料中显示产品。我的代码如下。

但是这里是错误:值不能为空。参数名称:source。

此代码有什么问题或有其他解决方法。

我的观点:

<section class="page-section" id="relatedprod">
<div class="container">
<div class="row middle">
 @foreach (Product prd in Model.Prod.Where(i=>i.userid==Model.userr.ID))
 {
 <div class="col-md-4">
 <figure class="card card-product mehsul">
<div class="img-wrap"> <img class="img-fluid mehsulimg" src="~/PublicFront/images/30off6ec8.jpg" alt=""> </div>
<div class="handhover">
<img class="img-fluid" src="~/PublicFront/images/serv2b712.jpg" alt="">
</div>
 <figcaption class="info-wrap">
  <h4 class="title">@prd.ProdName</h4>
  <p class="@prd.Price"></p>
</figcaption>
  <div class="bottom-wrap">
  <a href="" class="btn btn-sm btn-primary float-right">Order Now</a>
<div class="price-wrap h5">
<span class="price-new">$1280</span> <del class="price-old">$1980</del>
</div> <!-- price-wrap.// -->
</div> <!-- bottom-wrap.// -->
</figure>
 </div> <!-- col // -->
  }
 </div>
 </div>
</section>

控制器

public ActionResult MainAccount(int?id)
{
User us = Session["ActiveUser"] as User;
var vm = new HMViewM()
{
homesec1 = _context.homesec1slider.ToList(),
userr=us,
};
return View(vm);
 }
namespace HandMShop.ViewModel

{ 型号:

public class HMViewM
{
    public List<homesec1slider> homesec1 { get; set; }
    public User userr { get; set; }
    public  List<Category>  catg { get;set; }
    public List<Colour> colrs { get; set; }
  public List<PhotoProduct> Photopr { get; set; }
    public List<Product> Prod { get; set; }
}
}

public partial class Product
{
    [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", "CA2214:DoNotCallOverridableMethodsInConstructors")]
    public Product()
    {
        this.PhotoProducts = new HashSet<PhotoProduct>();
    }

    public int id { get; set; }
    public string ProdName { get; set; }
    public string Price { get; set; }
    public string Discount { get; set; }
    public Nullable<int> CategoryId { get; set; }
    public Nullable<int> AvailableID { get; set; }
    public string Description { get; set; }
    public string Material { get; set; }
    public Nullable<byte> Enable { get; set; }
    public Nullable<int> userid { get; set; }
    public Nullable<System.DateTime> prodpostDate { get; set; }
    public string ProdGenderId { get; set; }
    public string sifarishle { get; set; }
    public Nullable<int> LanguageId { get; set; }
    public Nullable<int> colourId { get; set; }
    public string Olcusu { get; set; }

    public virtual AvailableTb AvailableTb { get; set; }
    public virtual Category Category { get; set; }
    public virtual Colour Colour { get; set; }
    public virtual LanguageTb LanguageTb { get; set; }
    [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", "CA2227:CollectionPropertiesShouldBeReadOnly")]
    public virtual ICollection<PhotoProduct> PhotoProducts { get; set; }
    public virtual User User { get; set; }
}
}

enter image description here

1 个答案:

答案 0 :(得分:1)

好吧,看来您的产品列表属性为空,请使用下面的代码填充它。

public ActionResult MainAccount(int?id)
{
   User us = Session["ActiveUser"] as User;

   // add Prod = _context.Product.Where(p=>p.User.ID == us.ID).ToList()
   var vm = new HMViewM()
   {
      homesec1 = _context.homesec1slider.ToList(),
      userr = us,
      Prod = _context.Product.Where(p=>p.User.ID == us.ID).ToList()
   };

   return View(vm);
}
相关问题