RenderPage()加载局部页和传递数据
System.Web.WebPages.WebPageBase类的方法
public override HelperResult RenderPage(string path, params object[] data); 以下三种方式:
System.Web.WebPages.WebPageBase.PageData属性(public override IDictionary<object, dynamic> PageData)
System.Web.WebPages.WebPageBase.Page属性(public override dynamic Page)
System.Web.WebPages.WebPage.Model属性(public dynamic Model),注意区分System.Web.Mvc.WebViewPage.Model属性(public object Model)
index.cshtml 传递数据
@RenderPage("/_Footer.cshtml",
new { Title ="文档标题", Author=“作者” },new { Name="姓名", Age=23}
)
_Footer.cshtml 接收数据
1,PageData/Page key的方式,只能取到data数组的第一个值,并将其属性转为key,属性值转为value
<p>@PageData["Title"] , @PageData["Author"] </p> 输出: 文档标题,作者 ,注意这里的key不区分大小写
<p>@PageData["Name"] , @PageData["Age"] </p> 输出:null 或者使用Page属性
<p>@Page.Title , @Page.Author </p> 输出: 文档标题,作者 ,注意这里的key不区分大小写
<p>@Page.Name , @Page.Age </p> 输出:null
2,PageData索引的方式,data数组都可以输出
_Footer.cshtml 接收数据
<p>@PageData[0]</p> 输出:{ Title = "标题", Author = "作者" }
<p>@PageData[1]</p> 输出:{ Name = "姓名", Age = 23 }
<p>@PageData[2]</p> 输出:null,不报异常!!
总结:通过key的方式,只能取到参数data的第一个值;通过索引方式可以按照顺序取出data的所有值
3,Model属性取数据
_Footer.cshtml 接收数据
<p>@Model.Title , @Model.Author</p> 可以取到
<p>@Model.Name , @Model.Age</p>这个取不到 data数组的第一个匿名类赋值给了WebPage类的Model属性,因此可以使用”@Model.匿名类属性“ 的方式访问到。
类似 PageData["key"]/Page.key的方式,只能取到data数组的第一个值,优点是比PageData["key"]方式灵活,跟Page.key类似
//分析源代码,只有第二个参数会被转为model(System.Web.WebPages.WebPageBase类)
private WebPageContext CreatePageContextFromParameters(bool isLayoutPage, params object[] data)
{
object model = null;
if (data != null && data.Length > )
{
model = data[];//只有第一个参数会转为model
}
IDictionary<object, object> pageData = PageDataDictionary<object>.CreatePageDataFromParameters(this.PageData, data);
return WebPageContext.CreateNestedPageContext<object>(base.PageContext, pageData, model, isLayoutPage);
}
RenderPage()加载局部页和传递数据的更多相关文章
- JavaScript之加载表格、表单行数据[插件]
/*** * name:加载表格或表单数据[通用] * name:load-table-or-form-data-common.js * * author:zengtai * date:2017-07 ...
- 使用pjax时点击浏览器刷新按钮仅加载内容页的解决办法
pjax可以实现ajax的局部刷新功能,同时能改变地址栏的URL,因此支持浏览器的后退和前进功能. 但是,在使用中,若没有正确使用,仍然会出现一些问题. 比如,我们在使用pjax后,能够在不加载整个页 ...
- vs 2015 "加载该页时出错。" 解决方案
错误信息: 加载该页时出错. 未找到与约束 ContractName Microsoft.CodeAnalysis.Editor.TypeScript.ScriptContexts.ITypeSc ...
- EF如何操作内存中的数据以及加载相关联表的数据:延迟加载、贪婪加载、显示加载
之前的EF Code First系列讲了那么多如何配置实体和数据库表的关系,显然配置只是辅助,使用EF操作数据库才是每天开发中都需要用的,这个系列讲讲如何使用EF操作数据库.老版本的EF主要是通过Ob ...
- js 鼠标滚动到某屏时,加载那一屏的数据,仿京东首页楼层异步加载模式
js用处:在做商城时,首页图片太多,严重影响首页打开速度,所以我们需要用到异步加载楼层.js名称:鼠标滚动到某屏时,加载那一屏的数据,仿京东首页楼层模式js解释:1.用于商城的楼层内容异步加载,滚动条 ...
- 只用css实现“每列四行,加载完一列后数据自动填充到下一列”的效果
只用css实现“每列四行,加载完一列后数据自动填充到下一列”的效果.这个题目用图表示如下: 如果将题目换成“只用css实现每行四列,加载完一行后数据自动填充到下一行”,那这个问题就简单多了,相信大家都 ...
- JS加载获取父窗体传递的参数
JS加载获取父窗体传递的参数 $(document).ready(function () { var query = location.search.substring(1); var values ...
- @ConfigurationProperties(pref="")加载局部配置文件
刚开始@ConfigurationProperties(文件名)直接在参数里加文件名,其实是配置前缀pref="前缀".加载局部配置文件是@PropertySource(value ...
- javscript 实现iframe加载内容页出现LOADING效果
<div id="load" align="center"> <img src="http://sc.cnwebshow.com/u ...
随机推荐
- 前端必须会的!!!关于对HTTP协议的理解、HTTP协议原理分析
http协议学习系列 1. 基础概念篇 1.1 介绍 HTTP是Hyper Text Transfer Protocol(超文本传输协议)的缩写.它的发展是万维网协会(World Wide Web C ...
- Thread.setDaemon详解
Thread.setDaemon详解 线程分为两种类型:用户线程和守护线程.通过Thread.setDaemon(false)设置为用户线程:通过Thread.setDaemon(true)设置为守护 ...
- 第五章 用Helm部署Istio
5.1 Istio Chart概述 Helm是目前Istio官方推荐的安装方式.还可以对输入值进行一些调整,完成对Istio的部分配置工作.Istio Chart是一个总分结构,其分级结构和设计结构是 ...
- python学习(二十二) String(上)
str1 = "This is a 'test'" print(str1) str1 = 'This is a "test"' print(str1) str1 ...
- css 定位position总结
在CSS中,Position 属性经常会用到,主要是绝对定位和相对定位,简单的使用都没有问题,尤其嵌套起来,就会有些混乱,今记录总结一下,防止久而忘之. CSS position 属性值: absol ...
- node制作代理服务器
下面代码实现的功能是这样的: 首先创建一个HTTP服务器,当服务器接收到客户端的请求后,向"www.taobao.com"网站请求数据,当从该网站接受到的响应数据后,将响应数据发送 ...
- C链表
结构指针的应用,链表处理 1,链表的概念 链表是将若干数据项按一定规则连接起来的[数据类型]表,链表中的每一个数据称为一个节点,既链表是由称为节点的元素组成的,节点多少根据需要确定. 链表连接规则: ...
- 用C#操作IO端口1-用并口控制发光二极管
什么是端口? 端口包含了一系列信号线, 通过这个端口CPU可以同其他外部设备交换数据, 比如我们经常见到的Modem,打印机等. 通常情况下, 打开的信号是”1”, 关闭的信号是”0”. 并口在同一时 ...
- spring-boot-actuator健康监控
#健康监控 management.security.enabled=false health.mail.enabled =false http://localhost:54001/autoconfig ...
- 最流行的JavaScript代码规范
什么是最佳的JavaScript代码编程规范?这可能是一个众口难调的问题.那么,不妨换个问题,什么代码规范最流行? sideeffect.kr通过分析GitHub上托管的开源代码,得出了一些有趣的结果 ...