开发者

MVC3 Populate 'Create' View for related object

Related post: Populating a select box in a form using related ID in MVC3

I've got a Listview generated using MVC3 and ADO.NET Linq-to-Entities.

I have been able to create a simple list view, with an "Create" & "Edit" Action Link Command for creating a 'related object'.

 @Html.ActionLink("Create Shipping Profile", "../PrintProfile/Create", new { id = item.ProductId }) |
 @Html.开发者_StackOverflow中文版ActionLink("Edit Shipping Profile", "../PrintProfile/Edit", new { id = item.ProductId })

When I create the 'PrintProfile' I want the 'Create' view to be 'pre-populated' with the "ProductId" (which is the database table relation), so that I can create the profile, and edit the associated profile for each item in the list.

Here is the Create Controller for the PrintProfile:

    public ActionResult Create(int ProductId)
    {
        var entities = new CS_ShippingProfiles();
        entities.ProductId = ProductId; // Assign the ProductId I want to 'create'
        return View(entities);
    }

    [HttpPost]
    public ActionResult Create(CS_ShippingProfiles Profile)
    {
        if (ModelState.IsValid)
        {
            var entities = new LabelServiceEntities();
            entities.AddToCS_ShippingProfiles(Profile);
            entities.SaveChanges();

            return Redirect("/Products");
        }
        return View(Profile);
    }

But When I follow the link, I get a 'Null' parameter exception! What am I doing wrong?!


Your action parameter on the Create action is called ProductId so make sure you generate correct links:

@Html.ActionLink(
    "Create Shipping Profile", 
    "Create", 
    "PrintProfile", 
    new { ProductId = item.ProductId }, 
    null
) 
|
@Html.ActionLink(
    "Edit Shipping Profile", 
    "Edit", 
    "PrintProfile", 
    new { ProductId = item.ProductId }, 
    null
)

Also notice how controller and actions are specified instead of using some relative urls as you do (../PrintProfile/Create).

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜