发表日期:2019-04 文章编辑:小灯 浏览次数:2905
很多时候信息数据需要共享,一个最常用的应用场景就是手机版(独立手机,非响应式)本共享pc版本数据,下面以这个场景为例讲解。
假设手机版本对应信息栏目id为10,要调用pc栏目id等于1的信息数据,那么在手机模板中写如下代码就可以调取到pc数据。
<ul> @foreach(var item in Html.InfoDataList(new {ColumnId=1})) { string url = Html.InfoDataUrl((int)item.ColumnId,(int)item.Id); <li class="item clearfix"> <a href="@url" target="_blank">@item.Title</a> </li> } </ul>
但是这段代码有个问题,Html.InfoDataUrl得到的是信息所在的站点的内容页url地址,手机打开信息内容会跳转到pc站点去。
解决办法:用Html.InfoDataSharedUrl方法来调用,代码如下:
<ul> @foreach (var item in Html.InfoDataList(new { ColumnId = 1 })) { string url = Html.InfoDataSharedUrl(10,(int)item.Id); <li class="item clearfix"> <a href="@url" target="_blank">@item.Title</a> </li> } </ul>
注意Html.InfoDataSharedUrl第一个参数指定当前手机栏目id。
如果按上面写法,还是会存在两个问题:
1、如果手机版本不同栏目需要共享不同pc栏目的信息,ColumnId参数就要设置不同,就需要单独制作很多模板。
解决办法:栏目中添加一个下拉类型的自定义字段,关联pa_column表的name字段,可以直接在后台选择对应的pc栏目,然后模板中读取自定义字段后赋值给ColumnId参数,具体看页面后面的相关教程。
2、手机版本对应信息栏目id为10,也可能为11,12,如果手工指定具体指,每个栏目也需要建不同的模板。
解决办法:是用Html.CurrentColumnId()代替,这个方法获取当前信息栏目id。
日期:2019-04 浏览次数:3025
日期:2019-04 浏览次数:2994
日期:2019-04 浏览次数:2904
日期:2019-04 浏览次数:2742
日期:2019-04 浏览次数:2828
日期:2019-04 浏览次数:2994
日期:2019-04 浏览次数:2945
日期:2019-04 浏览次数:3205
日期:2019-04 浏览次数:3242
日期:2019-04 浏览次数:2905
日期:2019-04 浏览次数:3254
日期:2019-04 浏览次数:2687
日期:2019-04 浏览次数:2845
日期:2019-04 浏览次数:2954
日期:2019-04 浏览次数:2795
日期:2019-04 浏览次数:3264
日期:2019-04 浏览次数:3154
日期:2019-04 浏览次数:2838
日期:2019-04 浏览次数:3064
日期:2019-04 浏览次数:2890
日期:2019-04 浏览次数:2658
日期:2019-04 浏览次数:2960
日期:2019-04 浏览次数:2872
日期:2019-04 浏览次数:2966
日期:2019-04 浏览次数:2919
日期:2019-04 浏览次数:2792
日期:2019-04 浏览次数:2626
日期:2019-04 浏览次数:2661
日期:2019-04 浏览次数:2715
日期:2019-04 浏览次数:2756
Copyright ? 2013-2018 Tadeng NetWork Technology Co., LTD. All Rights Reserved.