mvc中传值

mvc中的页面传值,我们分为两种:一是从controller到view,另外就是从view到controller,其实也可以由从view到view。

 

1、从controller到view

主要是用TempData和ViewData ,ViewData只对当前Action有效,而TempData有点类似于Session, 可在所有View访问,一般用于记录错误信息.

Action代码:

public ActionResult Index()  
 
    ViewData["Message"] = "Welcome to ASP.NET MVC!";  
    return View();  

页面代码:

<h2><%= Html.Encode(ViewData["Message"]) %></h2> 
TempData使用方式与View使用方式一致.

在这里可以实现view与ViewData绑定

利用HtmlHelper创建TextBox时,使用名称与ViewData中的Key一致, 就会自动实现值绑定,如:

Name:<%= Html.TextBox("name") %> 
名称不相同的情况下,也可以利用TextBox的重载传值:

Name:<%= Html.TextBox("name", ViewData["Nm"]) %> 

2.View向Controller传值

1). 利用Action参数

public ActionResult Index(string name, string sex)  
 
    ViewData["Message"] = "Welcome to ASP.NET MVC!";  
    ViewData["name"] = name;  
    ViewData["sex"] = sex;  
    return View();  

        <form name="form1" action="/Home/Index" method="post">
            Name:<input type="text" name="name" /><br />
            Sex: <input type="text" name="sex" />
            <input type="submit" value="submit" />
        </form>
        <%
            if (ViewData["name"] != null)
            {
                Response.Write("your name is:" + ViewData["name"] + ",  your sex is:" + ViewData["sex"]);
                    
        %>
Action代码:
        public ActionResult Index(string name, string sex)
        {
            ViewData["Message"] = "Welcome to ASP.NET MVC!";
            ViewData["name"] = name;
            ViewData["sex"] = sex;
            return View();
        }

2).利用Request.From或Request.QueryString

public ActionResult Index()  
 
    ViewData["Message"] = "Welcome to ASP.NET MVC!";  
    ViewData["name"] = Request.Form["name"];  
    ViewData["sex"] = Request.Form["sex"];  
    return View();  

3). 利用FormCollection获取页面值

public ActionResult Index(FormCollection form)  
 
    ViewData["Message"] = "Welcome to ASP.NET MVC!";  
    User u=new User();  
    u.Name = form["Name"];  
    u.Password = form["Password"];  
    return View(u);  

4.传递强类型

1).添加一个传递强类型Model的Action

public ActionResult ModelDemo()  
        
            User u= new User() { UserName="li", Password="abcde" };  
            return View(u);  
       
对应的View也需要继随于ViewPage<User>, 对应代码如下:

<p>  
<%User u = (User)ViewData.Model;%>  
            UserName:   
            <%= Html.Encode(u.UserName) %>  
        </p>  
        <p>  
            Password:   
            <%= Html.Encode(u.Password) %>  
        </p >
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值