pageadmin CMS网站制作教程:附属表数据列表调用语法
列表调用语法
Html.SubDataList(参数1,参数2,参数3,参数4)
参数说明:
参数说明
类型
说明 是否可为null
参数1
object
预定义条件对象参数,包含固定属性 否
参数2 string
sql自定义条件
是
参数3
object
sql参数值
是
参数4
PageInfo
分页对象,如需要分页,必须设置此参数
是
注:第一个参数对象中必须定义Table或ParentTable/ParentField属性。
参数1常用属性:
属性
类型
说明
Table
string
要读取的附属表名,如不设置,必须设置ParentTable和ParentField
ParentTable string
父级表名称,必须和ParentField搭配使用
ParentField string 附属表的字段名称,必须和ParentField搭配使用
ParentId int
附属表对应的父级信息Id
ShowNumber int 默认为15,分页读取时此参数无效
OrderBy
string
数据排序方式,默认Id desc排序
Fields string
要读取的字段,不设置则由系统根据后台设置自动读取
Uid int 用户id
实例1:读取product_images附属表的前10条数据
@{
PageInfo pageInfo = new PageInfo()
{
PageSize = 10,
CurrentPage = (int)ViewBag.CurrentPage //获取当前页面页码,系统预设
};
}
模板中如何实现信息数据共享
很多时候信息数据需要共享,一个最常用的应用场景就是手机版(独立手机,非响应式)本共享pc版本数据,下面以这个场景为例讲解。
假设手机版本对应信息栏目id为10,要调用pc栏目id等于1的信息数据,那么在手机模板中写如下代码就可以调取到pc数据。
- @foreach(var item in Html.InfoDataList(new {ColumnId=1})) { string url = Html.InfoDataUrl((int)item.ColumnId,(int)item.Id);
- @item.Title
- }
解决办法:用Html.InfoDataSharedUrl方法来调用,代码如下:
- @foreach (var item in Html.InfoDataList(new { ColumnId = 1 })) { string url = Html.InfoDataSharedUrl(10,(int)item.Id);
- @item.Title
- }
如果按上面写法,还是会存在两个问题:
1、如果手机版本不同栏目需要共享不同pc栏目的信息,ColumnId参数就要设置不同,就需要单独制作很多模板。
解决办法:栏目中添加一个下拉类型的自定义字段,关联pa_column表的name字段,可以直接在后台选择对应的pc栏目,然后模板中读取自定义字段后赋值给ColumnId参数,具体看页面后面的相关教程。
2、手机版本对应信息栏目id为10,也可能为11,12,如果手工指定具体指,每个栏目也需要建不同的模板。
解决办法:是用Html.CurrentColumnId()代替,这个方法获取当前信息栏目id。
本文介绍pageadmin CMS中附属表数据列表的调用方法,包括列表调用语法及参数说明,并提供实例演示如何实现信息数据共享。
875

被折叠的 条评论
为什么被折叠?



