0

我正在使用 nopcommerce 2.2 并尝试在中使用局部视图ProductVariant_SKU_Man_Stock_Productbox.cshtml但出现错误:传递到字典中的模型项是类型

'System.Collections.Generic.List`1[Nop.Web.Models.Catalog.ProductModel+ProductVariantModel]',但此字典需要类型为 'Nop.Web.Models.Catalog.ProductModel+ProductVariantModel' 的模型项。

下面是_Productbox.cshtml

@model Nop.Web.Models.Catalog.ProductModel
<div class="product-item">
<h2 class="product-title">
@Model.Name
</h2>
<div class="description">
      @Html.Partial("_ProductVariant_SKU_Man_Stock",Model.ProductVariantModels)
    @Html.Raw(Model.FullDescription) <br />
    @Model.Size
</div>
<div class="add-info">
    <div class="prices">
        @Html.Partial("_ProductPrice", Model.ProductPrice)
    </div>
    <div class="buttons">
       @* <input type="button" value="@T("Products.Details")" class="productlistproductdetailbutton" onclick="setLocation('@Url.RouteUrl("Product", new { productId = Model.Id, SeName = Model.SeName })')" />
*@        @if (!Model.ProductPrice.DisableBuyButton)
        {
            <br />
            <input type="button" value="@T("ShoppingCart.AddToCart")" class="productlistaddtocartbutton" onclick="setLocation('@(@Url.RouteUrl("AddProductToCart", new { productId = Model.Id }))')" />
        }
     </div>
     </div>
     </div>

有没有其他方法可以做到这一点,因为我需要该部分视图中的一些字段才能在该视图中显示。

产品模型.cs:

 public class ProductModel : BaseNopEntityModel
{
    public ProductModel()
    {
        ProductPrice = new ProductPriceModel();
       // ProductSku = new ProductSkuModel();
        DefaultPictureModel = new PictureModel();
        PictureModels = new List<PictureModel>();
        ProductVariantModels = new List<ProductVariantModel>();
        SpecificationAttributeModels = new List<ProductSpecificationModel>();
    }

    public string Name { get; set; }

    public string ShortDescription { get; set; }

    public string FullDescription { get; set; }

    public string ProductTemplateViewPath { get; set; }

    public string MetaKeywords { get; set; }

    public string MetaDescription { get; set; }

    public string MetaTitle { get; set; }

    public string SeName { get; set; }
    public string Size { get; set; }
    public ProductPriceModel ProductPrice { get; set; }
    public bool DefaultPictureZoomEnabled { get; set; }
    public PictureModel DefaultPictureModel { get; set; }
    public IList<PictureModel> PictureModels { get; set; }
    public IList<ProductVariantModel> ProductVariantModels { get; set; }
    public IList<ProductSpecificationModel> SpecificationAttributeModels { get; set; }
    public class ProductVariantModel : BaseNopEntityModel
    {
        public ProductVariantModel()
        {
            ProductSku = new ProductSkuModel();
            GiftCard = new GiftCardModel();
            ProductVariantPrice = new ProductVariantPriceModel();
            PictureModel = new PictureModel();
            AddToCart = new AddToCartModel();
            ProductVariantAttributes = new List<ProductVariantAttributeModel>();
        }

        public string Name { get; set; }

        public bool ShowSku { get; set; }

        public string Sku { get; set; }

        public string Description { get; set; }

        public bool ShowManufacturerPartNumber { get; set; }

        public string ManufacturerPartNumber { get; set; }

        public string DownloadSampleUrl { get; set; }

        public GiftCardModel GiftCard { get; set; }

        public string StockAvailablity { get; set; }

        public ProductVariantPriceModel ProductVariantPrice { get; set; }

        public AddToCartModel AddToCart { get; set; }

        public PictureModel PictureModel { get; set; }
        public ProductSkuModel ProductSku { get; set; }

        public IList<ProductVariantAttributeModel> ProductVariantAttributes { get; set; }
        public class ProductVariantPriceModel : BaseNopModel
        {
            public string OldPrice { get; set; }

            public string Price { get; set; }
            public string PriceWithDiscount { get; set; }

            public decimal PriceValue { get; set; }
            public decimal PriceWithDiscountValue { get; set; }

            public bool CustomerEntersPrice { get; set; }

            public bool CallForPrice { get; set; }

            public int ProductVariantId { get; set; }

            public bool HidePrices { get; set; }

            public bool DynamicPriceUpdate { get; set; }
        }
        public class ProductSkuModel : BaseNopModel
        {


            public string Sku { get; set; }

            public bool ShowSku { get; set; }
        }

想要使用这个局部视图:

@model Nop.Web.Models.Catalog.ProductModel.ProductVariantModel
@if (!String.IsNullOrWhiteSpace(Model.StockAvailablity))
{
    <div class="stock">

        @Model.StockAvailablity
    </div>
 }
<div class="clear">
</div>
@if (!String.IsNullOrWhiteSpace(Model.Sku) && Model.ShowSku)
{
    <div class="sku">

        @Model.Sku
    </div>
}
<div class="clear">
</div>
@if (!String.IsNullOrWhiteSpace(Model.ManufacturerPartNumber) && Model.ShowManufacturerPartNumber)
{
    <div class="manufacturerpartnumber">

        @Model.ManufacturerPartNumber
    </div>
}
4

2 回答 2

4

还有一种替代方法,您可以将库存数量等属性ProductVariant_SKU_Man_Stock带入其中_Productbox.cshtml,而无需使用局部视图。

方法如下:

添加下面这组代码中Productmodel.cs,有一个嵌套类叫做

public class ProductPriceModel : BaseNopModel
{
  //here declare stockquantity 
   public int stockqty { get; set; }
}

catalogcontroller.cs,

有一个函数叫做

private ProductModel.ProductPriceModel PrepareProductPriceModel(Product product)
{ 
  //ADD THIS CODE BELOW
  model.stockqty=productvariants[0].StockQuantity;
}

_Productbox.cshtml添加

@if (Model.ProductPrice.stockqty <= 0)
{
   <div class="innerrtcarts"> 
    insert out of stock message or image
    </div>
}
于 2012-02-03T06:46:57.960 回答
0

_ProductVariant_SKU_Man_Stock 视图应该是单个 ProductVariantModel 并且您正在给它一个它们的列表。如果您知道您将只有一个 Variant,那么只需将该行更改为

@Html.Partial("_ProductVariant_SKU_Man_Stock",Model.ProductVariantModels.First())
于 2011-12-16T16:49:10.177 回答