0

我正在尝试将当前日期传递到文本框中,因为用户无法在此字段中输入值。这将写入数据库。我这样做的方式是,我不能在数据库中写入,因为表中的字段是 NULLABLE,所以不记录。我怎样才能做到这一点?

@Html.TextBox("DATA_HORA", string.Format("{0:dd/MM/yyyy}", DateTime.Now), new { disabled = "disabled", @readonly = "readonly", Style = "width:100px;" })

谢谢你们。

- 编辑 -

我正在使用 ADO.NET 实体框架。“创建”页面是在我创建控制器时自动生成的。

-- 编辑 2 --

我的控制器:

namespace enChamados.Controllers
{ 
    public class ChamadosController : Controller
    {
        private enChamados_ModeloContainer db = new enChamados_ModeloContainer();

        //
        // GET: /Chamados/

        public ViewResult Index()
        {
            return View(db.CHAMADOS.ToList());
        }

        //
        // GET: /Chamados/Details/5

        public ViewResult Details(int? id)
        {
            CHAMADOS chamados = db.CHAMADOS.Find(id);
            return View(chamados);
        }

        //
        // GET: /Chamados/Create

        public ActionResult Create()
        {
            return View();
        } 

        //
        // POST: /Chamados/Create

        [HttpPost]
        public ActionResult Create(CHAMADOS chamados)
        {
            if (ModelState.IsValid)
            {
                db.CHAMADOS.Add(chamados);
                db.SaveChanges();
                return RedirectToAction("Index");
            }

            return View(chamados);
        }

        //
        // GET: /Chamados/Edit/5

        public ActionResult Edit(int? id)
        {
            CHAMADOS chamados = db.CHAMADOS.Find(id);
            return View();
        }

        //
        // POST: /Chamados/Edit/5

        [HttpPost]
        public ActionResult Edit(CHAMADOS chamados)
        {
            if (ModelState.IsValid)
            {
                db.Entry(chamados).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            return View();
        }

        //
        // GET: /Chamados/Delete/5

        public ActionResult Delete(int? id)
        {
            CHAMADOS chamados = db.CHAMADOS.Find(id);
            return View(chamados);
        }

        //
        // POST: /Chamados/Delete/5

        [HttpPost, ActionName("Delete")]
        public ActionResult DeleteConfirmed(int id)
        {            
            CHAMADOS chamados = db.CHAMADOS.Find(id);
            db.CHAMADOS.Remove(chamados);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

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

2 回答 2

0

正如 Brian P 回答的那样,您可以为此字段创建一个 html 编辑器

创建一个 DateTime EditorTemplate(在 Views\Shared 文件夹中添加一个名为 EditorTemplates 的文件夹),如下所示:

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<Nullable<System.DateTime>>" %>
<% if ( Model.HasValue )
   { %>
    <%: Html.TextBox( "" , String.Format( "{0:ddd, MMM d, yyyy}" , Model.Value )  )%>
<% }
   else
   { %>
   <%: Html.TextBox( "" , String.Format( "{0:ddd, MMM d, yyyy}" , DateTime.Now )  )%>
<% } %>

从你的角度来看使用

<%: Html.EditorFor(model => model.nameOfYourField) %> 
于 2013-03-25T16:56:48.783 回答
0

如果要在模型上设置不应更改的日期,则不应使用文本字段。不仅没有理由在视图层中传递信息,而且如果模型绑定器可以访问该字段,则它可能会被更改。如果您的最终用户知道如何在他们的浏览器中使用开发工具,即使隐藏、禁用或只读字段仍然可以修改。

在您的控制器中只需设置日期:

[HttpPost]
public ActionResult Create(CHAMADOS chamados)
{
    if (ModelState.IsValid)
    {
        chamados.CreatedDate = DateTime.Now;
        db.CHAMADOS.Add(chamados);
        db.SaveChanges();
        return RedirectToAction("Index");
    }

    return View(chamados);
}

或者对于这样的事情,你实际上是在设置一个默认值,通常在你的模型中设置它更容易:

private DateTime? createdDate = null;
public DateTime CreatedDate
{
    get { return createdDate ?? DateTime.Now; }
    set { createdDate = value; }
}

然后,您不必在控制器中执行任何操作。CreatedDate 将在保存时自动填充当前日期和时间。

于 2013-03-25T20:14:13.913 回答