RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 865169
Accepted
Alexandr
Alexandr
Asked:2020-08-07 00:54:55 +0000 UTC2020-08-07 00:54:55 +0000 UTC 2020-08-07 00:54:55 +0000 UTC

asp.net mvc 5 将记录添加到带有导航字段的表中

  • 772

简短描述:向数据库添加条目时,模型被标记为无效,但代码调用

return View(order);

属性的验证错误(未填写,带有 Id 的字段已填写): public Product Product { get; set; } public Employee Employee { get; set; } public Customer Customer { get; set; }

查看代码

@using Bakery.Models
@model Bakery.Models.Order

@{
ViewBag.Title = "Добавить заказ";
}

@helper FIOEmployee(List<Employee> empCollection)
{ 
<select id="EmployeeId" name="EmployeeId">
    @foreach (var item in empCollection)
    {
        <option value="@item.Id">@string.Format("{0} {1} {2} {3}", item.IdentificationNumber, item.Surname, item.Name, item.Patronymic)</option>
    }
</select>
    }

    <h2>Добавить заказ</h2>

    @using (Html.BeginForm()) 
    {
    @Html.AntiForgeryToken()

<div class="form-horizontal">
    <h4>Order</h4>
    <hr />
    @Html.ValidationSummary(true, "", new { @class = "text-danger" })
    <div class="form-group">
        @Html.LabelFor(model => model.ProductId, htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.DropDownListFor(model => model.ProductId, ViewBag.Products as SelectList)
            @Html.ValidationMessageFor(model => model.ProductId, "", new { @class = "text-danger" })
        </div>
    </div>

    <div class="form-group">
        @Html.LabelFor(model => model.CustomerId, htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.DropDownListFor(model => model.CustomerId, ViewBag.Customers as SelectList)
            @Html.ValidationMessageFor(model => model.CustomerId, "", new { @class = "text-danger" })
        </div>
    </div>

    <div class="form-group">
        @Html.LabelFor(model => model.EmployeeId, htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @FIOEmployee(ViewBag.Employees as List<Employee>)
            @Html.ValidationMessageFor(model => model.EmployeeId, "", new { @class = "text-danger" })
        </div>
    </div>

    <div class="form-group">
        @Html.LabelFor(model => model.Count, htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.EditorFor(model => model.Count, new { htmlAttributes = new { @class = "form-control" } })
            @Html.ValidationMessageFor(model => model.Count, "", new { @class = "text-danger" })
        </div>
    </div>

    <div class="form-group">
        @Html.LabelFor(model => model.Price, htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.EditorFor(model => model.Price, new { htmlAttributes = new { @class = "form-control" } })
            @Html.ValidationMessageFor(model => model.Price, "", new { @class = "text-danger" })
        </div>
    </div>

    <div class="form-group">
        <div class="col-md-offset-2 col-md-10">
            <input type="submit" value="Create" class="btn btn-default" />
        </div>
    </div>
</div>
 }

<div>
@Html.ActionLink("Назад к списку", "Index")
</div>

控制器代码:

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Linq;
using System.Threading.Tasks;
using System.Net;
using System.Web;
using System.Web.Mvc;
using Bakery.Models;

namespace Bakery.Controllers
{
public class OrderController : Controller
{
    private BakeryContext db = new BakeryContext();

    // GET: Orders
    public async Task<ActionResult> Index()
    {
        var orders = db.Orders.Include(p => p.Product).Include(p => p.Customer).Include(p => p.Employee);
        return View(await orders.ToListAsync());
    }

    // GET: Orders/Create
    public ActionResult Create()
    {
        SelectList products = new SelectList(db.Products, "Id", "Name");
        var employees = db.Employees.ToList();
        SelectList customers = new SelectList(db.Customers, "Id", "Name");
        ViewBag.Products = products;
        ViewBag.Employees = employees;
        ViewBag.Customers = customers;
        return View();
    }

    // POST: Orders/Create
    // To protect from overposting attacks, please enable the specific properties you want to bind to, for 
    // more details see http://go.microsoft.com/fwlink/?LinkId=317598.
    [HttpPost]
    [ValidateAntiForgeryToken]
    public async Task<ActionResult> Create([Bind(Include = "Id,Product,ProductId,Employee,EmployeeId,Customer,CustomerId,Count,Price")] Order order)
    {
        SelectList products = new SelectList(db.Products, "Id", "Name");
        var employees = db.Employees.ToList();
        SelectList customers = new SelectList(db.Customers, "Id", "Name");
        ViewBag.Products = products;
        ViewBag.Employees = employees;
        ViewBag.Customers = customers;
        order.Customer = db.Customers.Find(order.CustomerId);
        order.Employee = db.Employees.Find(order.EmployeeId);
        order.Product = db.Products.Find(order.ProductId);
        if (ModelState.IsValid)
        {
            order.Id = Guid.NewGuid();
            db.Orders.Add(order);
            await db.SaveChangesAsync();
            return RedirectToAction("Index");
        }

        return View(order);
    }

    // GET: Orders/Edit/5
    public async Task<ActionResult> Edit(Guid? id)
    {
        if (id == null)
        {
            return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
        }
        Order order = await db.Orders.FindAsync(id);
        if (order == null)
        {
            return HttpNotFound();
        }
        return View(order);
    }

    // POST: Orders/Edit/5
    // To protect from overposting attacks, please enable the specific properties you want to bind to, for 
    // more details see http://go.microsoft.com/fwlink/?LinkId=317598.
    [HttpPost]
    [ValidateAntiForgeryToken]
    public async Task<ActionResult> Edit([Bind(Include = "Id,Count,Price")] Order order)
    {
        if (ModelState.IsValid)
        {
            db.Entry(order).State = EntityState.Modified;
            await db.SaveChangesAsync();
            return RedirectToAction("Index");
        }
        return View(order);
    }

    // GET: Orders/Delete/5
    public async Task<ActionResult> Delete(Guid? id)
    {
        if (id == null)
        {
            return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
        }
        Order order = await db.Orders.FindAsync(id);
        if (order == null)
        {
            return HttpNotFound();
        }
        return View(order);
    }

    // POST: Orders/Delete/5
    [HttpPost, ActionName("Delete")]
    [ValidateAntiForgeryToken]
    public async Task<ActionResult> DeleteConfirmed(Guid id)
    {
        Order order = await db.Orders.FindAsync(id);
        db.Orders.Remove(order);
        await db.SaveChangesAsync();
        return RedirectToAction("Index");
    }

    protected override void Dispose(bool disposing)
    {
        if (disposing)
        {
            db.Dispose();
        }
        base.Dispose(disposing);
    }
}
}

型号代码

using System;
using System.Collections.Generic;
using System.ComponentModel; 
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Linq;
using System.Web;

namespace Bakery.Models
{
public class Order
{
    public Order()
    {

    }

    public Order(Employee employee, Product product, Customer customer, Double count, Double price)
    {
        Id = Guid.NewGuid();
        Employee = employee;
        Product = product;
        Customer = customer;
        Count = count;
        Price = price;
    }

    /// <summary>
    /// Код
    /// </summary>
    [Key]
    public Guid Id { get; set; }

    /// <summary>
    /// Сотрудник
    /// </summary>
    [DisplayName("Сотрудник")]
    [Required]
    public Employee Employee { get; set; }
    [System.Web.Mvc.HiddenInput(DisplayValue = false)]
    public Guid? EmployeeId { get; set; }

    /// <summary>
    /// Изделие
    /// </summary>
    [DisplayName("Изделие")]
    [Required]
    public Product Product { get; set; }
    [System.Web.Mvc.HiddenInput(DisplayValue = false)]
    public Guid? ProductId { get; set; }

    /// <summary>
    /// Заказчик
    /// </summary>
    [DisplayName("Покупатель")]
    [Required]
    public Customer Customer { get; set; }
    [System.Web.Mvc.HiddenInput(DisplayValue = false)]
    public Guid? CustomerId { get; set; }

    /// <summary>
    /// Количество заказанных изделий
    /// </summary>
    [DisplayName("Количество изделий (шт.)")]
    [Required]
    [Range(1, Double.MaxValue, ErrorMessage = "Количество не может быть меньше 1")]
    public double Count { get; set; }

    /// <summary>
    /// Цена
    /// </summary>
    [DisplayName("Цена (руб.)")]
    [Required]
    [Range(0.1, Double.MaxValue, ErrorMessage = "Цена не может быть меньше 0.1")]
    public double Price { get; set; }

}
}
c#
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Buka
    2020-08-07T01:15:57Z2020-08-07T01:15:57Z

    在 Create 的 Get 方法中,你有这个集合:

    ViewBag.Products = products;
    ViewBag.Employees = employees;
    ViewBag.Customers = customers;
    

    但它不在 Post 方法中,我们必须记住,对于每个新请求,模型都是新的,因此必须重新填充员工和产品

    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5