@html.action 访问分部视图,EF5+MVC4系列(11)在主视图中用Html.RenderPartial调用分部视图(ViewDate传值);在主视图中按钮用ajax调用子action并在...

一:主视图中使用Html.RenderPartial来调用子视图(注意,这里是直接调用子视图,而没有去调用子Action )

在没有使用母版页的主视图中(也就是设置了layout为null的视图中),使用 Html.RenderPartial  可以调用分部视图(只调用视图,不调用action),并且使用 ViewData 来从主Action里面传值到主视图,或者是分布视图

a0d52f3d916323fbfb791c3a59cb9499.png

最后生成的html如下

b308f2ed4e5827ae67f7a33688857aa2.png

二:在主视图中按钮用ajax调用子action并在子action中使用return PartialView返回分布视图(return view 和return PartialView 的区别)

这种情景是,我们在主视图中,有个按钮,点击之后,调用ajax去请求另外一个子Action ,并且  子Action 用 Return View或者是Return PartialView 来返回完整视图,或者是分部视图.

这个很简单,就是在 主视图中,调用 ajax,来访问子 action的方法,  如果要传递至,就自己在 ajax 里面来写参数

ebd90f68bdf9b1c89135f954ca19952a.png

后台

public ActionResult Login()

{

return PartialView("PartialLogin"); //如果是返回分部视图,那么不走_ViewStart.cshtml页面,直接就去 分部视图页

//return View("PartialLogin"); //如果是返回全部视图,那么就走_ViewStart.cshtml页面(这里还要走Layout的中设置的页面),然后再走视图页面

}

我们看看我们的分部视图 PartialLogin.cshtml 很简单,就两行代码

c1a074503c4b1329dc9b4b6d6df29ffe.png

我们先看看 通过return PartialView("PartialLogin");返回的分部视图,由于是没有走 _ViewStart.cshtml 的,所以直接就返回视图里面的内容

2ba6a74c3d0127dc136155a7df28e8d8.png

我们再来看看  return View("PartialLogin"); 返回全部视图. 全部视图有个特点是会先走 ViewStart.cshtml 页面, 我们看看 ViewStart.cshtml中有什么代码

32440d49fa729c966375edb08c90d547.png

由于在ViewStart.cshtml 中的 Layout有设置页面,那么还会去执行这个页面中的代码

我们在代码中看到是一大段的代码,执行完这段之后,最后再去执行我们指定的视图  PartialLogin  ,注意,由于 在ViewStart 的Layout设置的页面 (_Layout.cshtml) 中有用到 RendyBody 这个方法,所以后面要有代码来填这个坑

6db9c5d4cb779174afbe43ff6addfda7.png

那么最后返回给前台的代码是?

e837255f2dcb7bf9e37642a9c1250eed.png

结论  当调用 子 action的时候,如果返回的是  return PartialView("PartialLogin");  则不走 _ViewStart.cshtml页面 , 直接走视图 .最后再返回给 主视图中的Ajax要调用到的地方

如果返回的是  return View("PartialLogin"); 那么就先走_ViewStart.cshtml页面(如果Layout有设置页面,那么先要走Layout中的页面),然后再正常走视图,最后再返回给 主视图中的 Ajax要调用到的地方

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。、可私 6信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 、可私信6博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 、可私信6博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值