不显示部分视图,否则会产生404错误

partial view is not display back anything error 404 is generated

本文关键字:错误 显示部 视图      更新时间:2023-09-26

我试图解决这个问题,我在部分视图路径url: localhost:49259/Panier/TableContent上得到了404错误。这个TableContent在Panier文件夹下。我不知道这个网址有什么问题。

TableContent是否应该在这个文件夹ViewModels下,因为它正在使用这个模型@ model Tp1WebStore3.ViewModels.ShoppingCartViewModel吗?

感谢

TableContent。cshtml(部分视图)from Panier

 @model Tp1WebStore3.ViewModels.ShoppingCartViewModel
 @{
     ViewBag.Title = "Table Content";
 }
 <a href="#" class="TableContent">
     <table>
         <tr>
             <th>
                 Produit
             </th>
             <th>
                 Prix (unitaire)
             </th>
             <th>
                 Quantite
            </th>
            <th></th>
         </tr>
         @foreach (var item in Model.CartItems)
         {
             <tr id="row-@item.ProduitId">
                 <td>
                     @Html.ActionLink(item.Produit.Description, "Details", "Produit", new { id = 
                         item.ProduitId }, null)
                 </td>
                 <td>
                     @item.Produit.Prix
                 </td>
                 <td id="item-count-@item.PanierId">
                     @item.Quantite
                 </td>
                 <td>
                     <a href="#" class="RemoveLink" data-id="@item.PanierId"> Enlever du panier 
                     </a>
                 </td>
             </tr>
         }
         <tr>
             <td>
                 Total
             </td>
             <td></td>
             <td></td>
             <td id="cart-total">
                 @Model.CartTotal
             </td>
         </tr>
     </table>
 </a>

索引。

 @model Tp1WebStore3.ViewModels.ShoppingCartViewModel
 @{
     ViewBag.Title = "Shopping Cart";
 }
 <script src="/Scripts/jquery-1.8.2.min.js" type="text/javascript"></script>
 <script type="text/javascript">
     $(function () {
         $('.RemoveLink').click(function () {
             $.ajax({
                 url: '/Panier/RemoveFromCart',
                 data: { id: $(this).data('id') },
                 type: 'POST',
                 cache: false,
                 success: function (result) {
                     $('#row-' + result.DeleteId).remove();
                     $('#row-' + result.DeleteId).fadeOut('slow');
                     $('#cart-status').text('Cart (' + result.CartCount + ')');
                     $('#update-message').text(result.Message);
                     $('#cart-total').text(result.CartTotal);
                     $.get("/Panier/TableContent").done(function (data) {     <==error 404
                          $("#TableContent").html(data); });
                  },
                  error: function(XMLHttpRequest, textStatus, errorThrown) { 
                       alert("Status: " + textStatus); alert("Error: " + errorThrown); 
                  }       
             });
             return false;
         });
     });
 </script>
 <h3>
     <em>Details</em> du panier:
 </h3>
 <p class="button">
     @Html.ActionLink("Checkout >>", "AddressAndPayment", "Checkout")
  </p>  
  <div id="update-message">
  </div>
  <div id="table-content">
      @Html.Partial("TableContent")    <=== partial view call
  </div>

PanierController.cs

 using System;
 using System.Collections.Generic;
 using System.Linq;
 using System.Web;
 using System.Web.Mvc;
 using Tp1WebStore3.Models;
 using Tp1WebStore3.ViewModels;
 namespace Tp1WebStore3.Controllers
 {
     public class PanierController : Controller
     {
         //
         // GET: /Panier/
         Tp1WebStoreDBEntities dbProduit = new Tp1WebStoreDBEntities();
         //
         // GET: /ShoppingCart/
         public ActionResult Index()
         {
             var cart = ShoppingCart.GetCart(this.HttpContext);
             // Set up our ViewModel
             var viewModel = new ShoppingCartViewModel
             {
                 CartItems = cart.GetCartItems(),
                 CartTotal = cart.GetTotal()
             };
             // Return the view
             return View(viewModel);
         }
         //
         // GET: /Store/AddToCart/5
         public ActionResult AddToCart(int id)
         {
             // Retrieve the album from the database
             var addedProduit = dbProduit.Produits
                  .Single(produit => produit.ProduitId == id);
             // Add it to the shopping cart
             var cart = ShoppingCart.GetCart(this.HttpContext);
             cart.AddToCart(addedProduit);
             // Go back to the main store page for more shopping
             return RedirectToAction("Index");
         }
         //
         // AJAX: /ShoppingCart/RemoveFromCart/5
         [HttpPost] 
         public ActionResult RemoveFromCart(int id)
         {
             // Remove the item from the cart
             var cart = ShoppingCart.GetCart(this.HttpContext);
             // Get the name of the album to display confirmation
             string produitDescription = dbProduit.Paniers
                 .Single(item => item.PanierId == id).Produit.Description;
             // Remove from cart
             int itemCount = cart.RemoveFromCart(id);
             // Display the confirmation message
             var results = new ShoppingCartRemoveViewModel
             {
                 Message = Server.HtmlEncode(produitDescription) +
                     " has been removed from your shopping cart.",
                 CartTotal = cart.GetTotal(),
                 CartCount = cart.GetCount(),
                 ItemCount = itemCount,
                 DeleteId = id
             };
             return Json(results);  
         /*    return View("CartSummary");  */
         }
         //
         // GET: /ShoppingCart/CartSummary
         [ChildActionOnly]
         public ActionResult CartSummary()
         {
             var cart = ShoppingCart.GetCart(this.HttpContext);
             ViewData["CartCount"] = cart.GetCount();
             return PartialView("CartSummary");
         }
     }
 }

你会想把你的局部视图保存在视图文件夹中(而不是视图模型)…具体的子目录由您决定,但我相信它将默认在shared中查找。

我建议在调用部分视图时指定更多的URL,看看是否可以解决您的问题…

例如:

Html.Partial("~/Views/Shared/TableContent.cshtml")

更多信息在这里:

从不同的文件夹(不共享)呈现部分


好吧,我意识到我误解了这个问题,404是由脚本调用而不是@Html生成的。文件底部的部分

我将按照注释中的这段代码…

$.get("~/Views/Shared/TableContent").done(function (data) {        $("#TableContent").html(data); });

我看到两个问题…首先,您将希望以不同的方式解析路径,因为"~"操作符在javascript中没有帮助。在这种情况下,您可以使用@url.Action(" tableccontent ")来获取服务器上的实际url,并将其传递给get语句。

第二个问题是,我认为TableContent只是一个没有相应操作的视图。这对于内联呈现Html很好。部分的,但是服务器不能在上下文之外呈现它。您需要添加一个相应的操作,并从ajax调用它。

您的控制器Panier似乎没有一个名为TableContent的方法,该方法应该返回部分视图TableContent.cshtml

另外,当您引用Url时,请尝试使用Url。ajax/get中的动作调用:

url: '/Panier/RemoveFromCart',
应:

url: '@Url.Action("RemoveFromCart","Panier")',

解决这个问题的另一种方法是在Panier Controller中创建一个动作tableccontent,它将调用分部视图tableccontent。TableContent。cshtml应该与Index(即/Views/Panier)在同一目录

public PartialViewResult TableContent()
{
    return PartialView("TableContent");
}

然后需要替换ajax调用

中的一行
$.get("/Panier/TableContent") 

$.get('@Url.Action("TableContent", "Panier")')