数据未在mvc3中从视图传递到控制器

时间:2013-06-01 06:35:02

标签: asp.net-mvc-3

当用户插入数据并点击添加按钮时,我正在尝试向表中添加一行..

我的控制器如下:

[HttpPost]
public ActionResult Index(PurchaseOrder purchaseorder,String btnSubmit)
{
    ViewBag.paymenttypes = Constants.PaymentType();
    ViewBag.supplierid = new SelectList(db.suppliers, "supplierid", "suppliername");
    ViewBag.productid = new SelectList(db.products, "productid", "productname");


    switch (btnSubmit)
    {
        case "Add":
            purchaseorder.purchasedetails.Add(purchaseorder.detail);
            break;
        case "Save":
            break;
    }

    return View(purchaseorder);
}

查看如下:

@using (Html.BeginForm("Index","PurchaseOrder",FormMethod.Post))
 {

 {
    @Html.ValidationSummary(true)
     @Html.ValidationMessageFor(model => model.purchase.billno)
 <div class="block-content collapse in">
 <div style="float:left; margin-left:20px;">@Html.TextBoxFor(model => model.purchase.purchasedate, new { @readonly = "readonly" })</div>
<div style="float:left; margin-left:20px;">@Html.TextBoxFor(model => model.purchase.billno, new { @Value = "Enter Bill Number" })</div>
<div style="float:left; margin-left:20px;"> @Html.DropDownListFor(model => model.purchase.cashcredit,
new SelectList(ViewBag.paymenttypes, "key", "value"))</div>
<div style="float:left; margin-left:20px;">@Html.DropDownList("supplierid", "Select Supplier")</div>
<div style="clear:both;"></div>
<hr />
<table style="margin-left:10px;" class="table table-striped" id="details">
    <tr>
        <th>
            Product
        </th>
        <th>
            Cost Price
        </th>
        <th>
            Quantity
        </th>
        <th>
            Selling Price
        </th>
    </tr>
    <tr>
        <td>
           @Html.DropDownList("productid", "Select Product")
        </td>
        <td>
            @Html.TextBoxFor(model => model.detail.costprice)
         </td>
        <td>
            @Html.TextBoxFor(model => model.detail.quantity)
         </td>
        <td>
          @Html.TextBoxFor(model => model.detail.sellingprice)
        </td>
        <td>

               </td>
    </tr>
    @foreach (var item in Model.purchasedetails)
    {
    <tr id="abc">
        <td >
            @Html.DisplayFor(modelItem => item.product.productcode)
        </td>
        <td >
            @Html.DisplayFor(modelItem => item.costprice)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.quantity)
        </td>
        <td >
            @Html.DisplayFor(modelItem => item.sellingprice)
        </td>
    </tr>
    }
</table>
 <input type="submit" id="Add" name="btnSubmit", value="Add" />
  <input type="submit" id="Save" name="btnSubmit", value="Save" />

   </div>

我想要做的就是当用户向表格行添加新数据并按下添加按钮时。它必须添加到模型和表中。

我只是得到空指针异常。任何人都可以帮助我。

这是异常的堆栈跟踪 '/'应用程序中的服务器错误。 你调用的对象是空的。 描述:执行当前Web请求期间发生未处理的异常。请查看堆栈跟踪,以获取有关错误及其在代码中的起源位置的更多信息。

异常详细信息:

System.NullReferenceException: Object reference not set to an instance of an object.
Source Error: 
Line 44:             {
Line 45:                 case "Add":
Line 46:                     purchaseorder.purchasedetails.Add(purchaseorder.detail);
Line 47:                     break;
Line 48:                 case "Save":
Source File: C:\Users\Ayush Raj Aryal\Desktop\SidhhaBaba\SidhhaBaba\siddha-baba-project\SiddhaBaba\SiddhaBaba\Controllers\Admin\PurchaseOrderController.cs    Line: 46

Stack Trace:
[NullReferenceException: Object reference not set to an instance of an object.]
SiddhaBaba.Controllers.PurchaseOrderController.Index(PurchaseOrder purchaseorder, String btnSubmit) in 
C:\Users\Ayush Raj Aryal\Desktop\SidhhaBaba\SidhhaBaba\siddha-baba-project\SiddhaBaba\SiddhaBaba\Controllers\Admin\PurchaseOrderController.cs:46

任何人都可以帮我解决这个问题

1 个答案:

答案 0 :(得分:1)

我认为你在这一行得到例外:

purchaseorder.purchasedetails.Add(purchaseorder.detail);

原因是purchaseorder.purchasedetails可能未设置,因为您没有提交任何purchasedetails。

您列出了已购买的详细信息,但使用@Html.DisplayFor未生成<input>元素。如果您希望提交所购买的详细信息数据,则必须执行以下操作:

@foreach (var item in Model.purchasedetails)
{
    <tr id="abc">
        <td >
            @Html.DisplayFor(modelItem => item.product.productcode)
            @Html.HiddenFor(modelItem => item.product.productcode)
        </td>
    </tr>