文档章节

SharePoint 创建 Lookup 类型的Site Column解决跨站问题

 木宛城主
发布于 2015/03/02 19:42
字数 935
阅读 14
收藏 0

在某些情况下,我们需要去引用其他List中的数据,比如在网站集(Site Collection)上有个List叫Country,在其子网站(WebSite)有个List叫Employee,如果要在子Site上的Employee去引用Country中的数据,一般我们会在Site Collection上创建一个网站栏(Site Column)。这是一种解决方案。还有一种解决方案,我们也可以在项目中创建一个Lookup 类型的 Site Column,其Scope为Site,顺着思路,我理所应当的创建了一个Site Column,Scope=Site,但事实上远没这么简单。

其实两种方式都是可以的,先来看第一种解决方式:

网站设置下创建网站栏

  • 我以SharePoint 2013 Foundation为例,登录SharePoint Site Collection,点击Site settings:

  • 找到Web Designer Galleries(Web设计器库),点击Site columns:

  • 点击创建:

  • 创建Lookup(查阅项)类型的Column,并为其选择信息来源:

 

接着,就可以在子站中使用该Column,同理进入子站,打开Employee List,点击列表设置,为其添加Column:

在相应的组中找到自定义的Lookup类型的Column,点击添加即可:

这样就可以在跨站引用其他List中的数据了:

当然,这是一种最简单的方法,但不妥的是需要手动去添加,而且在项目中也不能给List添加此字段,我突然想到为何不在项目中创建一个Site Column,这样就可以批量化的去进行一些操作了,从而避免了多次需要手动添加。

在项目中创建Lookup类型的Site Column

  • 创建Site Column,为了和之前的作区分,故叫"国籍2":
<?xml version="1.0" encoding="utf-8"?>
<Elements xmlns="http://schemas.microsoft.com/sharepoint/">  
  <Field
       ID="{605b3bbf-40ed-4cc7-85a3-8b6547129bf1}"
       Name="CountryField"
       StaticName="CountryField"
       DisplayName="国籍2"
       Type="Lookup" SourceID="http://schemas.microsoft.com/sharepoint/v3" List="Lists/CountryList"
       ShowField="LinkTitleNoMenu"
       Required="FALSE"
       Group="Custom Site Columns">
  </Field>
</Elements>
  • 部署项目之后,找到此自定义的Site Column,发现其信息来源这儿压根没有设置上去:

看来要在项目中新建一个Look up类型的Site Column并非这么简单,所以我尝试用PowerShell导出 Employee List,查看国籍Field的SchemaXml

Add-PSSnapin "Microsoft.SharePoint.PowerShell"
$site=Get-SPSite "Http://oa.kingdom.com/sites/test"
$web=$site.AllWebs["testSite1"]
$list=$web.Lists.TryGetList("Employee")
$list|Select -ExpandProperty SchemaXml |Out-File -FilePath "C:\field.txt"
  • 找到自定义的"国籍"Field:
<Field Type="Lookup" 
 DisplayName="国籍" 
 Required="FALSE" 
 EnforceUniqueValues="FALSE" List="{d5907d52-99f0-49ed-85cb-f72f6e3bce4f}" WebId="0defd255-9fe9-454b-a34a-be7a86c84597"
 ShowField="Title"
 UnlimitedLengthInDocumentLibrary="TRUE" 
 Group="自定义栏" 
 ID="{44e07d2e-e367-479d-863e-179bdd5bd674}" SourceID="{0defd255-9fe9-454b-a34a-be7a86c84597}" 
 StaticName="国籍" 
 Name="_x56fd__x7c4d_" 
 Version="1" 
 ColName="int1" 
 RowOrdinal="0"/>

找到不同了吗?"国籍"和"国籍2"两个都是Type=Lookup类型的字段,它们最大的不同是List和SourceID、WebId数据的不同,经过调试,发现List应该对应的是List 自己的ID,SourceId对应的是List所在的web Id,所以我需要动态的改变这两个值。到底怎样实现呢,当然是Feature 激活的时候去动态修改。

public override void FeatureActivated(SPFeatureReceiverProperties properties)
        {
            SPSite targetSite = properties.Feature.Parent as SPSite;

            using (SPSite site = new SPSite(targetSite.ID))
            {
                using (SPWeb web = site.OpenWeb())
                {
                    SPField lookupField = web.Fields.TryGetFieldByStaticName("CountryField");

                    if (lookupField != null)
                    {
                        // 得到CountryField的Schema
                        XDocument fieldSchema = XDocument.Parse(lookupField.SchemaXml);
                        XElement root = fieldSchema.Root;
                        if (root.Attribute("List") != null)
                        {
                            // 得到List对应的url
                            string listurl = root.Attribute("List").Value;

                            SPFolder listFolder = web.GetFolder(listurl);
                            if (listFolder != null && listFolder.Exists)
                            {
                                
                                XAttribute attrList = root.Attribute("List");
                                if (attrList != null)
                                {
                                    
                                    attrList.Value = listFolder.ParentListId.ToString();
                                }

                                XAttribute attrWeb = root.Attribute("SourceID");
                                if (attrWeb != null)
                                {
                                    
                                    attrWeb.Value = web.ID.ToString();
                                }
                      
                                lookupField.SchemaXml = fieldSchema.ToString();
                            }
                        }
                    }

                }
            }

        }
  • 我们到网站设置下查看以下是否已经正确设置了信息来源:

  • 接着我们再去验证下跨站是否正确,可以在子站Employee下获取到CountryList中的数据,发现可以跨站获取国籍2对应List中的数据,这将为我们今后在项目中可以重用这个字段提供了方便:

总结

源代码点击下载。

 

 

 

© 著作权归作者所有

共有 人打赏支持
粉丝 2
博文 222
码字总数 199010
作品 0
黄浦
私信 提问
[翻译]Training Site Template—Part 1:介绍

原文地址:http://blogs.msdn.com/sharepointdesigner/archive/2007/03/10/training-site-template-part-1-introduction.aspx 译者注:本来想逐字逐句的翻译,可是到后来觉得这样也没必要,就...

zting科技
2017/01/10
0
0
sharepoint 2013 使用outlook 打开sharepoint 任务失败

使用outlook 2010打开失败时可以检查下面几点: Applies To: Workflow Conductor 2.1 and higher SharePoint Server 2010 and Microsoft Office SharePoint Server 2007 Microsoft Outlook 2......

pclzr
2017/03/23
0
0
Sharepiont之页面模型

本文主要包括以下几方面内容: 1.页面布局和母版页 2.页面布局模型 3.页面模型 4.字段控件和控件模板 5.页面处理模型 1.页面布局和母版页 母版页和页面布局是MOSS2007中最基本的两个模板模型...

zting科技
2017/01/10
0
0
企业内部IT一体化系列之四:WEB平台 SharePoint服务配置

上文中我们只是简单的安装完了SharePoint,其实最最重要的服务配置还在后面,SharePoint自己单独拿出来就可以讲很久,而我这里的目的只是方便大家部署一个可以承载System Center Service Man...

kneight
2014/07/29
0
0
企业内部IT一体化系列之五:基于SharePoint的IT服务台

之前我的文章有介绍过: 帮助台的页面如下: 这个站点的结构其实很简单,主要就是一个大的服务请求的自定义列表,下面加了一个文件列表的Webpart,文件路径是公司的打印服务器。右边是一个组...

kneight
2014/07/29
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Confluence 6 教程:在 Confluence 中导航

当你对 Confluence 有所了解后,你会发现 Confluence 使用起来非常简单。这个教程主要是针对你使用的 Confluence 界面进行一些说明,同时向你展示在那里可以进行一些通用的任务和操作。 空间...

honeymose
今天
2
0
sed, awk 练习

1. sed打印某行到某行之间的内容 2. sed 转换大小写 将单词首字母转化大写 将所有小写转化大写 3. sed 在某一行最后面添加一个数字 4. 删除某行到最后一行 解析: {:a;N;$!ba;d} :a : 是...

Fc丶
今天
2
0
babel6升级到7,jest-babel报错:Requires Babel "^7.0.0-0", but was loaded with "6.26.3".

自从将前端环境更新到babel7,jest-babel之前是基于babel6的,执行时候就会报:Requires Babel "^7.0.0-0", but was loaded with "6.26.3". 很烦,因为连续帮好几台电脑修复这个问题,所以记...

曾建凯
今天
1
0
探索802.11ax

802.11ax承诺在真实条件下改善峰值性能和最差情况。 如何改善今天的Wi-Fi? 在决定如何改进当前版本以外的Wi-Fi时,802.11ac,IEEE和Wi-Fi联盟调查了Wi-Fi部署和行为,以确定更广泛使用的障碍...

linuxprobe16
今天
2
0
使用linux将64G的SDCARD格式化为FAT32

一、命令如下: sudo fdisk -lsudo mkfs.vfat /dev/sda -Isudo fdisk /dev/sda Welcome to fdisk (util-linux 2.29.2). Changes will remain in memory only, until you decide to wri......

mbzhong
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部