ahmedbelal Ответов: 2

У меня есть проблема в коде, связанная с печатью отчета о покупках между двумя периодами. Я получаю сообщение об ошибке: @товар.продукты.марка всегда имеет значение null


У меня есть проблема в коде, связанная с печатью отчета о покупках между двумя периодами. Я получаю ошибку: @item.products.ProductName всегда null

При обработке запроса возникло необработанное исключение.
NullReferenceException: ссылка на объект не установлена на экземпляр объекта.
AspNetCore.Views_Reports_reportPurchaseDate.<executeasync>b__13_0() в reportPurchaseDate.cshtml, строка 76

Стек Запрос Куки Заголовки Маршрутизация
NullReferenceException: ссылка на объект не установлена на экземпляр объекта.
AspNetCore.Views_Reports_reportPurchaseDate.<executeasync>b__13_0() в reportPurchaseDate.cshtml
+
@item.products.значение ProductName


Что я уже пробовал:

мой контроллер

public class ReportsController : Controller    
{
    private MyDbContext _Context;

    public ReportsController(MyDbContext Context)
    {
        _Context = Context;
    }

    protected override void Dispose(bool disposing)
    {
        _Context.Dispose();
    }

    public bool getRole()
    {
        bool role = false;
        string group_id = HttpContext.Session.GetString("group_id");
        string username = HttpContext.Session.GetString("username");
        string Page_Current = HttpContext.Request.Path;
        var db = _Context.Permission_pages.Where(c => c.group_id.ToString() == group_id && c.page_name ==            
Page_Current).Select(p => p.page_name).ToList();

        if (db.Count != 0)
        {
            role = true;
        }
        else
        {
            role = false;
        }

        return role;
    }    

    public ActionResult reportPurchaseDate(DateTime datefrom, DateTime    dateto)
    {
        bool isrole = getRole();

        if (isrole == true)
        {
            var rpt = _Context.orderDetails.Where(c => c.masterID.Order_Kind_ID == 1 && c.masterID.DateAdded >= datefrom &&
c.masterID.DateAdded <= dateto)
                .Include(c => c.masterID)
                .Include(c => c.products.ProductName)
                .ToList();

            return View(rpt);
        }
        else
        {
            return RedirectToAction("noaccess", "HomeController");
        }
    }
}



мой взгляд

@model IEnumerable<orderdetails>
@{    
     ViewData["Title"] = "report purchase Date";    
     Layout = "~/Views/Shared/_Layout.cshtml";
}
<h1> Report Purchase</h1>

    
    <table class="table"><tbody><tr>        <td>            
        </td>        <td>            Date From
        </td>    </tr>    <tr>        <td>            @Html.TextBox("dateto")
        </td>        <td>           Date To
        </td>    </tr>    <tr>        <td>            
        </td>        <td>        </td>    </tr>    </tbody></table>    <hr>
        <hr>    <div class="row">
    <div class="col-md-12">
        <div class="content-panel">
            <h4>
                class="fa fa-angle-right">
                Report Purchase
            </h4>
            <hr>
            
                                    @foreach (var item in Model)
                    {
                                            }

                <table class="table"><thead>                    <tr>                        <td>                           Product Name
                        </td>                        <td>                          Price
                        </td>                        <td>                           Quantity
                        </td>                        <td>                           Date
                        </td>                    </tr>                </thead>                <tbody><tr>                            <td>                                @item.products.ProductName

                            </td>                            <td>                                @item.Product_Price
                            </td>                            <td>                                @item.Product_Quantity
                            </td>                            <td>                                    @Html.DisplayFor(modelItem => item.masterID.DateAdded)
                                </td>                        </tr></tbody>            </table>
        </div>
    </div>
    </div>
    
    @section Scripts
    {    
        
        function PrintElem(elem) {
            Popup($(elem).html());
        }

        function Popup(data) {
            var myWindow = window.open('', 'my div', 'height=500,width=600');
            myWindow.document.write('<html><head><title>my div</title>');
            myWindow.document.write('<link rel="stylesheet" href="/lib/bootstrap/css/bootstrap.min.css" type="text/css" />');
            myWindow.document.write('</head><body >');
            myWindow.document.write(data);
            myWindow.document.write('</body></html>');
            myWindow.document.close(); // necessary for IE >= 10

            myWindow.onload = function () { // necessary if the div contain images

                myWindow.focus(); // necessary for IE >= 10
                myWindow.print();
                myWindow.close();
            };
        }    
        
    }

F-ES Sitecore

Если ProductName имеет значение null, то возникает проблема либо с тем, как соотносятся Ваши таблицы, либо с данными в них. У нас нет доступа ни к тому, ни к другому, так что мы ничем не можем помочь. Используйте SQL Profiler, чтобы точно узнать, какой SQL выполняет ваш код, и перейти оттуда.

2 Ответов

Рейтинг:
2

MadMyche

Я поместил несколько HTML-комментариев в ваш блок кода, которые должны помочь вам двигаться в правильном направлении...
Spoonboy могу сказать "There is no 'item' " по крайней мере , не в тот момент кода. Он существовал только внутри (пустого) инструкция foreach петля

<div class="row">
   <div class="col-md-12">
      <div class="content-panel">
         <h4>class="fa fa-angle-right">Report Purchase</h4>
         <hr>
         @foreach (var item in Model) {
            <!-- nothing in this loop -->
         }
         <table class="table">
            <thead>
               <tr>
                  <td>   Product Name</td>
                  <td>  Price</td>
                  <td>   Quantity</td>
                  <td>   Date</td>
               </tr>
            </thead>
            <tbody>
               <tr>
                  <td>@item.products.ProductName</td> <!-- what is "item" ? -->
                  <td>@item.Product_Price</td>
                  <td>@item.Product_Quantity</td>
                  <td>@Html.DisplayFor(modelItem => item.masterID.DateAdded)</td>
               </tr>
            </tbody>
         </table>
      </div>
   </div>
</div>


Рейтинг:
1

OriginalGriff

Это одна из самых распространенных проблем, которые нам задают, и это также та, на которую мы меньше всего готовы ответить, но вы больше всего готовы ответить сами.

Позвольте мне просто объяснить, что означает ошибка: вы пытались использовать переменную, свойство или возвращаемое значение метода, но оно содержит null - что означает, что в переменной нет экземпляра класса.
Это немного похоже на карман: у вас есть карман в рубашке, который вы используете, чтобы держать ручку. Если вы сунете руку в карман и обнаружите, что там нет ручки, вы не сможете подписать свое имя на листе бумаги - и вы получите очень смешные взгляды, если попытаетесь! Пустой карман дает вам нулевое значение (здесь нет ручки!), поэтому вы не можете сделать ничего, что обычно делали бы, когда вы извлекли свою ручку. Почему он пуст? Вот в чем вопрос - может быть, вы забыли взять ручку, когда уходили из дома сегодня утром, или, возможно, вы оставили ручку в кармане вчерашней рубашки, когда снимали ее вчера вечером.

Мы не можем сказать, потому что нас там не было, и, что еще важнее, мы даже не можем видеть вашу рубашку, не говоря уже о том, что находится в кармане!

Вернемся к компьютерам, и вы каким - то образом сделали то же самое-и мы не можем увидеть ваш код, а тем более запустить его и узнать, что содержит null, когда это не должно быть.
Но вы можете - и Visual Studio поможет вам здесь. Запустите свою программу в отладчике, и когда она выйдет из строя, VS покажет вам строку, в которой она обнаружила проблему. Затем вы можете начать просматривать различные его части, чтобы увидеть, какое значение равно null, и начать просматривать свой код, чтобы узнать, почему. Поэтому поставьте точку останова в начале метода, содержащего строку ошибки, и снова запустите программу с самого начала. На этот раз VS остановится перед ошибкой и позволит вам изучить, что происходит, пройдя через код, глядя на ваши значения.

Но мы не можем этого сделать - у нас нет вашего кода, мы не знаем, как его использовать, если бы он у нас был, у нас нет ваших данных. Так что попробуйте - и посмотрите, сколько информации вы можете узнать!