在 SharePoint 中添加设备通道面板代码片段
设备通道面板是一种代码段,您可将其添加到母版页或页面布局中,以控制对所创建的每个通道呈现的内容。 设备通道面板的主要目的是在不同的通道上有选择地显示单个页面布局中的不同页字段。
设备通道面板代码段简介
设备通道面板是可添加到母版页或页面布局中以控制您创建的每个通道所呈现内容的控件。 设备通道面板是指定一个或多个通道的容器;如果呈现页面时,一个或多个这些通道处于活动状态,则还将呈现该设备通道面板的所有内容。 设备通道面板可包括任何类型的内容(包括到 CSS 文件或 .js 文件的链接)。 它是一种包括特定通道的特定内容的简单方法。
使用设备通道面板最常用的方案也许是有选择地包括特定通道的一部分页面布局。 例如,您可使页面布局包含用于长问候语和短问候语的单独的文本字段。 通过将页字段置于设备通道面板内,可仅对电话显示短问候语和仅对桌面显示长问候语。 设备通道面板的内容不会显示在已排除的通道中,事实上,根本不会呈现该内容,这样避免了内容通过网络传送。 因此,使用设备通道面板是在特定通道上显示内容比使用 CSS 类 Display:None
更好的方法,因为设备通道面板有助于减少特定通道的页面权重。
还可在母版页上使用设备通道面板。 例如,如果具有可容纳两种不同设备(或两个不同的浏览器) 而几乎不需要进行更改的母版页,则可使用设备通道面板保留特定于其中任一设备的母版页上的内容。
使用设备通道面板有以下两个限制:
- 显示模板 由于显示模板呈现在客户端,而设备通道面板在服务器端运行,因此您无法在显示模板内使用设备通道面板。 相反,应在页面布局上的设备通道面板中使用两个不同的内容搜索 Web 部件,或使用 JavaScript 变量在显示模板本身中触发所需的行为。
- Web 部件区域 不能在设备通道面板中插入 Web 部件区域。 若要让作者向页面添加 Web 部件,并且不担心移动设备的页面权重,可以向设备通道面板添加 RTF 编辑器页面字段,然后指示作者在其中添加 Web 部件。 可以直接向设备通道面板添加 Web 部件(而无需使用 Web 部件区域)。
插入设备通道面板代码段
像所有代码段一样,您可以从代码段库中添加设备通道面板代码段。 若要导航到代码段库,必须首先选择一个要编辑的母版页或页面布局。
插入设备通道面板代码段
浏览到您的发布网站。
在页面右上角中,选择"设置"齿轮,然后选择"设计管理器"。
在设计管理器的左导航窗格中,选择"编辑母版页"或"编辑页面布局",具体取决于您所编辑的文件类型。
选择要在其中添加代码段的母版页或页面布局的名称。
若要打开代码段库,请选择服务器端预览右上角的"代码段"。
在功能区的"设计"选项卡上,选择"设备通道面板"。
在代码段库右侧的"关于此组件"下,单击或选择节标题可展开或折叠属性组,然后配置需要的所有自定义设置。
名为"重要信息"的一节包含决定此特定代码段如何工作的属性。 对于设备通道面板,"IncludedChannels"属性是最重要的。 对于此属性,输入您要显示此设备通道面板所包含的内容的每个设备通道的别名。 如果您输入多个别名,请用逗号将每个别名隔开。
注意
如果编辑设备通道列表中的通道别名,必须手动查找并更新设计文件中的任何别名,包括更新使用此别名的每个设备通道面板的 IncludedChannels 属性。
在您配置好任何其他属性后,选择"更新"。 这将更新页面左侧的 HTML 代码段,以便该标记反映出您的自定义设置。 您可以随时选择“重置”将所有属性恢复为其默认设置。
在代码段库左侧的"HTML 代码段"下,选择"复制到剪贴板"。
在您的 HTML 编辑器中,打开您计算机上的映射网络驱动器,然后打开您要向其添加代码段的母版页或页面布局对应的 HTML 文件。
有关详细信息,请参阅 如何:将网络驱动器映射到 SharePoint 母版页库。
在 HTML 文件中,将代码段粘贴到希望显示标记的位置。
如果您将代码段添加到页面布局,请确保将代码段粘贴到 PlaceHolderMain 内部。
将
class="DefaultContentBlock"
的<div>
替换为您自己的特定内容。通常,如果您要向页面布局添加设备通道面板,则您可以通过在面板内复制页字段来替换
<div>
。保存该页面,然后刷新设计管理器中的服务器端预览,以确保设备通道面板按预期方式显示。
若要在不同通道上预览面板,您可以向 URL 添加查询字符串参数。 例如,可以将查询字符串变量
"DeviceChannel=YourChannelAlias"
追加到服务器端预览中任何页面的 URL。
理解代码段标记
设备通道面板代码片段的两个最重要部分是 IncludedChannels 属性和 <div>
(其中,class="DefaultContentBlock"
)。 IncludedChannels 属性默认为空。 在属性网格的“重要信息”部分中,应输入要在此面板中显示内容的设备通道的别名(用逗号分隔)。
注意
如果您更改设备通道列表中的别名,则还必须更改在您标记中出现的该别名,包括使用该别名的每个设备通道面板的 IncludedChannels 属性。
<div>
应将 位置class="DefaultContentBlock"
替换为要为包含的频道显示的任何特定内容。 设备通道面板可包括几乎任何类型的内容,包括到 CSS 文件或 .js 文件的链接。 使用设备通道面板最常用的方案是包括特定通道的页面布局中的特定页字段。 在这种情况下,您复制页字段标记,其中 <div>
位于设备通道面板内部。
<div data-name="DeviceChannelPanel">
<!--CS: Start Device Channel Panel Snippet-->
<!--SPM:<%@Register Tagprefix="Publishing" Namespace="Microsoft.SharePoint.Publishing.WebControls" Assembly="Microsoft.SharePoint.Publishing, Version=15.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c"%>-->
<!--MS:<Publishing:DeviceChannelPanel runat="server" IncludedChannels="MyPhoneChannel, MyTabletChannel">-->
<!--PS: Start of READ-ONLY PREVIEW (do not modify)--><!--PE: End of READ-ONLY PREVIEW-->
<div class="DefaultContentBlock" style="border:medium black solid; background:yellow; color:black; margin:20px; padding:10px;">
You should replace this div with content that renders based on your Device Channel Panel Properties.
</div>
<!--PS: Start of READ-ONLY PREVIEW (do not modify)--><!--PE: End of READ-ONLY PREVIEW-->
<!--ME:</Publishing:DeviceChannelPanel>-->
<!--CE: End Device Channel Panel Snippet-->
</div>