加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc-3 – 如何在razor视图中设置@ model.attribute?

发布时间:2020-12-15 19:06:26 所属栏目:asp.Net 来源:网络整理
导读:我有一个必填字段,字符串属性{get; set}并且想要在razor中设置它的值。是类似下面的可能吗? @model.attribute = "whatever' 解决方法 首先,资本化重要。 @model(小写字母“m”)是Razor视图中的保留关键字,用于在视图顶部声明模型类型,例如: @model MyN
我有一个必填字段,字符串属性{get; set}并且想要在razor中设置它的值。是类似下面的可能吗?
@model.attribute = "whatever'

解决方法

首先,资本化重要。

@model(小写字母“m”)是Razor视图中的保留关键字,用于在视图顶部声明模型类型,例如:

@model MyNamespace.Models.MyModel

稍后在文件中,可以使用@ Model.Attribute(大写“M”)引用所需的属性。

@model声明模型。模型引用模型的实例化。

第二,您可以为模型分配一个值,然后在页面中使用它,但是当页面提交到控制器操作时,它不会持久,除非它是表单字段中的值。为了在模型绑定过程中将值返回到模型中,您需要将值分配给表单字段,例如:

选项1

在控制器动作中,您需要为页面的第一个视图创建一个模型,否则当您尝试设置Model.Attribute时,Model对象将为null。

控制器:

// This accepts [HttpGet] by default,so it will be used to render the first call to the page
public ActionResult SomeAction()
{
    MyModel model = new MyModel();
    // optional: if you want to set the property here instead of in your view,you can
    // model.Attribute = "whatever";
    return View(model);
}

[HttpPost] // This action accepts data posted to the server
public ActionResult SomeAction(MyModel model)
{
    // model.Attribute will now be "whatever"
    return View(model);
}

视图:

@{Model.Attribute = "whatever";} @* Only do this here if you did NOT do it in the controller *@
@Html.HiddenFor(m => m.Attribute); @* This will make it so that Attribute = "whatever" when the page submits to the controller *@

选项2

或者,由于模型是基于名称的,因此可以跳过在控制器中创建模型,并且只需为表单字段命名与模型属性相同的名称。在这种情况下,将名为“Attribute”的隐藏字段设置为“whatever”将确保在页面提交时,值“whatever”将在模型绑定过程中绑定到模型的Attribute属性。注意,它不必是一个隐藏字段,只是任何具有name =“Attribute”的HTML输入字段。

控制器:

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

[HttpPost] // This action accepts data posted to the server
public ActionResult SomeAction(MyModel model)
{
    // model.Attribute will now be "whatever"
    return View(model);
}

视图:

@ Html.Hidden(“Attribute”,“whatever”);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读