xml - 自定义字段定义

标签 xml xslt sharepoint sharepoint-2013

在 SharePoint 2013 上,我在处理通过 schema.xml 文件定义的列表中的字段时遇到问题。我们从 2007 年升级到它工作正常,但升级到 2013 后,从新创建列表时它不再工作。

历史上:

该字段是一个自定义字段,它输出一个用 javascript 动态链接包裹的图像。这是使用显示模式和 cdata 定义的。

我们在 schema.xml 文件中定义了如下字段:

<Field ID="{A54A4AE0-CA79-47b0-819E-32DC1B3F5AFB}" ReadOnly="TRUE" Type="Computed" Name="Book" Sortable="FALSE" Filterable="FALSE" DisplayName="Book" ClassInfo="Icon" AuthoringInfo="(link to book item)" SourceID="http://schemas.microsoft.com/sharepoint/v3" StaticName="Book" FromBaseType="TRUE">
        <DisplayPattern>
          <HTML><![CDATA[<a href="javascript:" OnClick="javascript:this.href=L_Menu_BaseUrl + '/Lists/Bookings/NewForm.aspx?Session_x0020_Name=]]></HTML>
          <Column Name="ID" />
          <HTML><![CDATA[';GoToLink(this);return false;" target="_self">]]></HTML>
          <HTML><![CDATA[<img border="0" alt="]]></HTML>
          <HTML>Book</HTML>
          <HTML><![CDATA[" src="/_layouts/images/Book.GIF">]]></HTML>
          <HTML><![CDATA[</a>]]></HTML>
        </DisplayPattern>
      </Field>

当使用此模式从新启动列表时,它不再有效,它会创建书籍字段,但它只是空白。

我尝试过的:

经过研究,我了解到自定义字段现在意味着用 xsl 文件定义:

C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\15\TEMPLATE\LAYOUTS\XSL

所以我创建了一个名为:fldtypes_Book.xsl

的 xls 文件

其中的内容如下所示(目前我只是想输出简单的文本来让它工作):

<xsl:stylesheet xmlns:x="http://www.w3.org/2001/XMLSchema"
                xmlns:d="http://schemas.microsoft.com/sharepoint/dsp"
                version="1.0"
                exclude-result-prefixes="xsl msxsl ddwrt"
                xmlns:ddwrt="http://schemas.microsoft.com/WebParts/v2/DataView/runtime"
                xmlns:asp="http://schemas.microsoft.com/ASPNET/20"
                xmlns:__designer="http://schemas.microsoft.com/WebParts/v2/DataView/designer"
                xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
                xmlns:msxsl="urn:schemas-microsoft-com:xslt"
                xmlns:SharePoint="Microsoft.SharePoint.WebControls"
                xmlns:ddwrt2="urn:frontpage:internal">  
  <xsl:template match="FieldRef[@ID='A54A4AE0-CA79-47b0-819E-32DC1B3F5AFB']" mode="Computed_body"  priority="1">
    <xsl:param name="thisNode" select="."/>
    <span>Hello.</span>      
  </xsl:template>
</xsl:stylesheet>

同样,这不起作用,它只是输出该字段,但该字段为空。

我知道该字段正在与 xsl 文件 Hook ,因为如果我在文件中输入了一些错误的标签或随机困惑,列表就会中断。

24/08/2015 - 更新

经过研究我发现了这个:

https://msdn.microsoft.com/en-us/library/office/jj220061.aspx

并尝试将 js 文件上传到母版页并在列表 Web 部件设置中链接到它,但没有任何反应,我的 js 文件的内容:

(function () {

//   Initialize the variables for overrides objects
    var overrideCtx = {};
    overrideCtx.Templates = {};

//  alert("Override call worked");

//  Use BaseViewID and ListTemplateType to narrow focus/scope on 
//  which web parts on the page are affected
//  overrideCtx.BaseViewID = 1;
//  overrideCtx.ListTemplateType = 100;

    /*
     * Using the Fields override leaves the rest of the rendering intact, but 
     * allows control over one or more specific fields in the existing view
     */
    overrideCtx.Templates.Fields = {
        'Book': { 'View' : 'Hello' }
    };

    /*
     * Register the template overrides.
     */
    SPClientTemplates.TemplateManager.RegisterTemplateOverrides(overrideCtx);
})();

非常感谢任何帮助。

最佳答案

在 SharePoint 2013 中引入了客户端呈现(又名 CSR),用于呈现 ListView 、列表表单和搜索结果。与以前的 SharePoint 呈现系统(2010 年的 XSLT 和 2007 年的 CAML)不同,CSR 是客户端呈现模式,并且是 SharePoint 2013 中的默认。要熟悉 CSR,我建议阅读以下文章:SharePoint 2013 Client Side Rendering: List Views .

如何通过 CSR 在 SharePoint 2013 的 ListView 中自定义字段呈现

以下示例演示如何自定义LinkTitle列表中的Phones列渲染。

JavaScript 模板:

SP.SOD.executeFunc("clienttemplates.js", "SPClientTemplates", function() {

  SPClientTemplates.TemplateManager.RegisterTemplateOverrides({
     Templates: {
        Fields: {
           'LinkTitle': {'View': phoneIconRenderer}
        }
     }
  });

});


function phoneIconRenderer(ctx) {
    var item = ctx.CurrentItem;
    return '<img src="/SiteAssets/' +  item.Title + '.png" />';  
}

如何应用更改

至少有两个选项可用:

  1. 使用 JSLink property
  2. 在 ListView 所在的页面放置JavaScript模板

选项 1:

  1. 将指定模板保存为文件
  2. 将文件上传到例如 Site Assets 图书馆
  3. 为 ListView Web 部件指定 JS Link 属性示例:~site collection/SiteAssets/Phones.js

选项 2:

以下是如何使用第二个选项应用更改:

  1. 将页面切换到编辑模式
  2. 在 ListView Web 部件的正下方添加 Script Editor Web 部件。
  3. 将指定代码用script标签括起来放到Script Editor中,例如:<script type="text/javascript">{Template JS code goes here}</script>
  4. 保存页面

结果

enter image description here

关于xml - 自定义字段定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32093537/

相关文章:

java - 解析 RESTful XML 响应并在 JTable 中显示

c# - 使用 Xml Schema Inference 和 XDocument 以编程方式从 XML 创建 XSD schema

xml - 使用 XSLT 创建站点是否有意义

xslt - key 的使用 : Consolidating multiple <ul> with intervening <p> elements

r - 将文件从 R 保存到 SharePoint 文件夹

带有 XML 的 Android 按钮样式背景

php - 如何使用 PHP 解析带有冒号标记的 XML 节点

xml - XSLT 在输出文件中注入(inject)不需要的命名空间

sharepoint - CAML 查询 : how to filter folders from result set?

JQUERY AJAX - 如何将凭据(用户和密码)传递给 Sharepoint Web 服务