asp.net mvc3中母版页+局部刷新的用法

本文详细介绍了MVC3框架中母版页(_Layout.cshtml)的作用及其如何与控制器(Controller)和视图(View)交互,特别关注了母版页如何通过`@html.Raw()`方法获取数据,并展示了局部刷新(Partial View)的实现方式,通过实例代码解释了如何使用a标签结合`data-ajax-update`和`data-ajax`属性来实现场景中的内容更新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

      项目的Views文件夹下有个shared的文件夹,在它的的下面有个_Layout.cshtml的文件,也就是母版页。他并没有controller,但是里面的数据从哪里获得呢?mvc3提供了一个方法@html.Raw(string str)。比如你要在<div></div>里面写一些内容 就可以这样用<div>@html.Raw("<div>123566</div>")</div>   str可以在任意类中获得。

  _Layout.cshtml 代码如下

<!DOCTYPE html>
<html>
<head>
    <title>@ViewBag.Title</title>
    <script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
    <script type="text/javascript" src="/Scripts/jquery.unobtrusive-ajax.min.js"></script> //实现局部刷新要引入这两个js文件 切记
</head>

<body>
<div id="main">// 这个main 下面讲局部刷新时会用到
   @RenderBody() //这句话的意思就是 谁用到我母版页 谁就得把你自己的内容放在里面 比如说下面的index视图中@{ Layout ="~/Views/Shared/_Layout.cshtml";}
</div>
 <span>13216465464656</span>  
  <a href="/test2/ajaxtest" data-ajax-update="#main" data-ajax="true">hsidfh哦该哦iasjoijg</a> //讲解局部刷新时会用到
</body>
</html>

    下面开始用法

           第一步 要新建一个controller和view视图 比如 我们建一个叫testcontroller 还有一个Index视图

          在global.asax 里面修改路由(这部分内容可以上网查找资料 我也不是太了解) 看下面代码

        public static void RegisterRoutes(RouteCollection routes)
        {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

            routes.MapRoute(
                "Default", // 路由名称
                "{controller}/{action}/{id}", // 带有参数的 URL
                new { controller = "test", action = "Index", id = UrlParameter.Optional } // 参数默认值
            );
        }

   把黑色字体改成你要首先进入的controller和actionname的名字。

第二部  上面所说的index视图如下

   @{
    Layout ="~/Views/Shared/_Layout.cshtml";//=后面的就是文章开头所说的_Layout.cshtml
}

<!DOCTYPE html>

<html>
<head>
    <title>Index</title>
</head>
<body>
    <div>
    1452525555hsdkhfjsd
    </div>
   
</body>
</html>

  当你运行的时候 index视图中的1452525555hsdkhfjsd 会出现 id=main的div中  母版页的用法就这样

下面讲局部刷新

    假如你你有一个a标签 放在index视图中或者_Layout中  <a href="/test2/ajaxtest" data-ajax-update="#main" data-ajax="true">hsidfh哦该哦iasjoijg</a>

点击这个a标签 就会把ajaxtest里面的内容更新到id为main的div中

  局部刷新就这样

 写的不好 见谅





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值