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

asp.net-mvc – 如何在单个视图中使用两个表单

发布时间:2020-12-16 00:02:57 所属栏目:asp.Net 来源:网络整理
导读:我可以在一个视图中添加多个表单,如何使用它.这可以仅使用一个模型来完成,还是需要针对不同的形式使用不同的模型.任何人都可以用一个很好的例子来解释我,或者向我推荐一篇详细解释的好文章. 解决方法 这是一个很好的问题,当我是mvc的新手时,我自己也遇到了问
我可以在一个视图中添加多个表单,如何使用它.这可以仅使用一个模型来完成,还是需要针对不同的形式使用不同的模型.任何人都可以用一个很好的例子来解释我,或者向我推荐一篇详细解释的好文章.

解决方法

这是一个很好的问题,当我是mvc的新手时,我自己也遇到了问题.

我认为这里的一个很好的例子是同一页面上的注册表单和登录表单.

关键字是ViewModel,这对解决此问题至关重要.

在您的Model类中:

public class LoginModel
{
    public string UserName { get; set; }
    public string UserPassword { get; set; }
}

public class RegisterModel
{
    public int UserId { get; set; }
    public string UserName { get; set; }
    public string UserPassword { get; set; } 
}

public class ViewModel
{
    public LoginModel LoginModel { get; set; }
    public RegisterModel RegisterModel { get; set; }
}

在你的控制器:

public ActionResult Index()
    {
        var model = new ViewModel();
        model.LoginModel = new LoginModel();
        model.RegisterModel = new RegisterModel();
        return View(model);
    }

在您的视图中,我使用了1个主视图和2个部分视图将其拆分:

主要观点:

@model YourProject.Models.ViewModel

@Html.Partial("_LoginForm",Model.LoginModel)
@Html.Partial("_RegisterForm",Model.RegisterModel)

部分视图_LoginForm:

@model YourProject.Models.LoginModel

@using (Html.BeginForm("Login","Home",FormMethod.Post))
{
    @Html.TextBoxFor(x => x.UserName)
    @Html.PasswordFor(x => x.UserPassword)

    <input type="submit" value="Log In" />
}

部分视图_RegisterForm:

@model YourProject.Models.RegisterModel

@using (Html.BeginForm("Register",FormMethod.Post))
{
    @Html.TextBoxFor(x => x.UserName)
    @Html.PasswordFor(x => x.UserPassword)

    <input type="submit" value="Register" />
}

请询问是否有任何代码不清楚.

(编辑:李大同)

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

    推荐文章
      热点阅读