zoukankan      html  css  js  c++  java
  • sharepoint2010 创建自定义列表

    转:http://boke.25k5.com/kan77298.html

    如何创建自定义列表

    首先了解创建自定义列表中涉及到的几个名词:栏、内容类型

    ①栏:栏即列、字段(Field),MSDN中给出的解释为:“字段”一词在 SharePoint Foundation 开发中有两个关系非常密切的含义。有时它指的是列表中的列,但如果提到单个列表项,“字段”一词g 8h"@的意思与“单元格”很接近,这里的单元格是表中某一列和某一行相交的部分。在一定程度上由于这一原因,“列”和“字段”在 SharePoint Foundation 开发中实际上是同义词。在 SharePoint Foundation  中,列不仅包含特定数据类型的数据,列本身也是一种类型,因为同一列可用于具有不同数据的多个列表。列可以保存在网站栏库中。通过编程或用户界面 (UI) 可将库中的网站栏添加到网站中的任何列表。通过编程或用户界面(例如,内容类型设计器)还可以将列添加到内容类型。

    ②内容类型:MSDN中给出的解释为:定义 SharePoint Foundation 列表或文档库中项目类别的元数据、工作流和行为。我的理解为:将多个栏组合起来描述某一类型的集合。比如我们想新建一个关于产品的内容类型,产品可能包含的属性:ID、名称、介绍等信息,那么我们g 8h"@可以将现有的栏库中得栏(如果没有需要新建栏)组合到一块构成一个内容类型。那么这个内容类型就可以用于多个地方,每次创建只需创建此内容类型的列表即可,而不需要创建自定义类型后编辑。

     

    下面将介绍通过编程的方式创建自定义列表:

    一、新建一个Sharepoint 2010 的空白项目

    二、创建内容类型(ContentType):在资源管理器中项目上点击右键—>添加新建项,选择内容类型,将其命名为Product,点击添加;会出现一个向导,在向导中选择项目,点击完成。此时会创建如图一中标注的内容类型的新项。

    图(一)

    打开Product的Elements.xml,<span @font-family:courier="" new;="" background-color:rgb(240,240,240)"="">并新建如下代码:

    <?xml version="1.0" encoding="utf-8"?>
    <Elements xmlns="http://schemas.microsoft.com/sharepoint/">
      <Field SourceID="http://schemas.microsoft.com/sharepoint/v3"
             ID="{36819A9B-E748-47D5-9949-A65DD195BF80}"
             Name="ProductDescription"
             DisplayName="Product Description"
             Group="My Custom Columns"
             Type="Text"
             DisplaceOnUpgrade="TRUE"></Field>
      <Field SourceID="http://schemas.microsoft.com/sharepoint/v3"
             ID="{5CD2C0C1-67AC-4F9E-BF21-463CFEE9B382}"
             Name="ProductID"
             DisplayName="Product ID"
             Group="My Custom Columns"
             Type="Number"
             DisplaceOnUpgrade="TRUE"></Field>
      <!-- 父内容类g
    8h"@型: 项目 (0x01) -->
      <ContentType ID="0x01001bc8deb250c04fa0bd7d541e4757c82a"
                   Name="Product"
                   Group="自定义内容类型"
                   Description="我的内容类型"
                   Inherits="TRUE"
                   Version="0">
        <FieldRefs>
          <FieldRef ID="{5CD2C0C1-67AC-4F9E-BF21-463CFEE9B382}" Name="ID"/>
          <FieldRef ID="{fa564e0f-0c70-4ab9-b863-0177e6ddd247}" Name="Title" DisplayName="Product Name"/>
          <FieldRef ID="{36819A9B-E748-47D5-9949-A65DD195BF80}" Name="Description"/>
        </FieldRefs>
      </ContentType>
    </Elements>


    代码中包含的元素如下:

    1. Elements:顶级元素
    2. Field:定义网站栏<g 8h"@="" div="">
    3. ContentType:定义单个内容类型
    4. FieldRefs:表示内容类型中包括的列引用的集合
    5. FieldRef:指定要在此内容类型中引用的列 

    下面主要介绍上述元素中(Field、ContentType、FieldRef)主要属性,其他属性请参见MSDN中介绍。

    1.  <Field SourceID="http://schemas.microsoft.com/sharepoint/v3"
               ID="{5CD2C0C1-67AC-4F9E-BF21-463CFEE9B382}"
               Name="ProductID"
               DisplayName="Product ID"
               Group="My Custom Columns"
               Type=g 8h"@"Number"
               DisplaceOnUpgrade="TRUE"></Field>
      属性 说明
      SourceID 可选属性,类型为 Text。包含定义字段的命名空间(如 http://schemas.microsoft.com/sharepoint/v3),或者在其中创建自定义字段的列表的 GUID。
      ID 必需属性,类型为 Text。唯一标识字段。该值应是包含在括号 ({}) 内的 GUID 的字符串表示形式。
      Name 必需属性,类型为 Text。字段的内部名称。该名称在列表或网站的字段集中必须为唯一。如有必要,SharePoint Foundation 会修改该值以保证其唯一性;否则,在字段g 8h"@定义的生命周期内,其不会更改。
      DisplayName 可选属性,类型为 Text。字段的显示名称。没有空格使用限制。最大长度为 255 个字符。该值可以是格式为$Resources:String 的资源引用。该显示名称可由用户编辑并且可在初始字段创建后更改。该名称在字段显示在表视图中时用作栏标题,在字段显示在表单中时用作表单标签。
      Group 可选属性,类型为 Text。指定字段所属的栏组。
      Type 必需属性,类型为 Text。字段的数据类型
      DisplaceOnUpgrade 可选属性,类型为 Boolean。如果字段已存在字段定义,则选择 TRUE 可强制使用该字段定义中指定的值更新字段属性。
    2.   <ContentType ID="0x01001bc8deb250c04fa0bd7d541e4757c82a"
                     Name="Product"
                     Group="自定义内容类型"
                     Description="我的内容类型"
                     Inherits="TRUE"
                     Version="0"></ContentType>
      属性 说明
      ID 必需属性,类型为g 8h"@ Text。指定内容类型的内容类型 ID。内容类型 ID 具有特定的格式。如果为ID 属性分配的值格式不正确,激活功能时将遇到错误。
      Name 必需属性,类型为 Text。指定内容类型名称。该值可以为对 $Resources:String 格式的资源的引用。名称本身的长度不能超过 128 个字符,并且不能包含   / : * ? " # % < > { } | ~ & 字符、两个连续的句点 (..) 或制表符等特殊字符。 如果添加内容类型的集合中存在另一个同名内容类型,则会出现错误。
      Group 可选属性,类型为 Text。指定内容类型分配到的内容类型组。内容类型组是用户定g 8h"@的组,可帮助您将内容类型分组到逻辑类别中。该值可以为对$Resources:String 格式的资源的引用。
      Description 可选属性,类型为 Text。提供要在 SharePoint Foundation 用户界面中显示的内容类型的说明。该值可以为对$Resources:String 格式的资源的引用。
      Inherits 可选属性,类型为 Boolean。此属性的值确定创建时内容类型是否从其父内容类型继承字段。
      Version 保留以供将来使用。
    3. <FieldRef ID="{fa564e0f-0c70-4ab9-b863-0177e6ddd247}" Name="Title" DisplayName="Product Name"/>
      g 8h"@
      属性 说明
      ID 必需属性,类型为 Text。指定此 FieldRef 元素引用的列的字段 ID。字段 ID 是 GUID 的字符串表示形式,包括大括号。值区分大小写。可以在位于以下路径的 fieldswss.xml 文件中查找内置字段的 ID:%ProgramFiles%Common FilesMicrosoft Sharedweb server extensions14TEMPLATEFEATURESfields。
      Name 必需属性,类型为 Text。列的名称。这是列的内部名称,并且保证在字段定义的生存期内绝不会更改此名称。它相对于列表中的字段集必须是唯一的。
      DisplayName

      必需属性,类型为 Text。列的显示名称。最大长度为 255 个字符。

      当字段在表视图中显示时,此属性的值将用作列标题;当字段在表单中显示时,此属性的值将用作表单g 8h"@标签。可以使用 DisplayName 属性将显示名称更改为不同于在字段本身上定义的名称的值。

    三、编写完内容类型后,创建列表定义。在资源管理器中右键项目—>添加新建项—>列表定义(ListDefinition),点击添加;此时会出现向导,将显示名称修改为ProductList,列表定义类型修改为自定义列表,保持为此列表定义添加列表实例的勾选状态,点击完成。会生成如图一中自定义列表中显示的结构。

    在此结构中主要是对Schema.xml文件的编写,下面为此XML的编写后的完整代码:

    <?xml version="1.0" encoding="utf-8"?>
    <List xmlns:ows="Microsoft SharePoint" Title="ProductList" FolderCreation="FALSE" EnableContentTypes="TRUE"
          Direction="$Rg
    8h"@esources:Direction;" Url="Lists/ListsAndSchemas-ProductList" BaseType="0"
          xmlns="http://schemas.microsoft.com/sharepoint/">
      <MetaData>
        <ContentTypes>
          <ContentTypeRef ID="0x01">
            <Folder TargetName="Item" />
          </ContentTypeRef>
          <ContentTypeRef ID="0x0120" />
          <ContentTypeRef ID="0x01001bc8deb250c04fa0bd7d541e4757c82a"></ContentTypeRef>
        </ContentTypes>
        <Fields>
          <Field ID="{5CD2C0C1-67AC-4F9E-BF21-463CFEE9B382}" Name="ID" DisplayName="Product ID" Type="Number"></Field>
          <Field ID="{fa564e0f-0c70-4ab9-b863-0177e6ddd247}" Name="Title" DisplayName="Product Name" Type="Text"></Field>
          <Field ID="{36819A9B-E748-47D5-9949-A65DD195BF80}" Name="Description" DisplayName="Product Descritpion&qug
    8h"@ot; Type="Text"></Field>
        </Fields>
        <Views>
          <View BaseViewID="0" Type="HTML" MobileView="TRUE" TabularView="FALSE">
            <Toolbar Type="Standard" />
            <XslLink Default="TRUE">main.xsl</XslLink>
            <RowLimit Paged="TRUE">30</RowLimit>
            <ViewFields>
              <FieldRef Name="LinkTitleNoMenu"></FieldRef>
              <FieldRef ID="{36819A9B-E748-47D5-9949-A65DD195BF80}" Name="Descritpion" DisplayName="Product Description"></FieldRef>
              <FieldRef ID="{5CD2C0C1-67AC-4F9E-BF21-463CFEE9B382}" Name="ID" DisplayName="Product ID"></FieldRef>
            </ViewFields>
            <Query>
              <OrderBy>
                <FieldRef Name="Modified" Ascending="FALSE"></FieldRef>
              </OrderByg
    8h"@>
            </Query>
            <ParameterBindings>
              <ParameterBinding Name="AddNewAnnouncement" Location="Resource(wss,addnewitem)" />
              <ParameterBinding Name="NoAnnouncements" Location="Resource(wss,noXinviewofY_LIST)" />
              <ParameterBinding Name="NoAnnouncementsHowTo" Location="Resource(wss,noXinviewofY_ONET_HOME)" />
            </ParameterBindings>
          </View>
          <View BaseViewID="1" Type="HTML" WebPartZoneID="Main" DisplayName="$Resources:core,objectiv_schema_mwsidcamlidC24;" DefaultView="TRUE" MobileView="TRUE" MobileDefaultView="TRUE" SetupPath="pagesviewpage.aspx" ImageUrl="/_layouts/images/generic.png" Url="AllItems.aspx">
            <Toolbar Type="Standard" />
            <XslLink Default="TRUE">main.xsl</XslLink>
            <RowLimit Pagg
    8h"@ed="TRUE">30</RowLimit>
            <ViewFields>
              <FieldRef Name="Attachments"></FieldRef>
              <FieldRef Name="LinkTitle"></FieldRef>
              <FieldRef ID="{5CD2C0C1-67AC-4F9E-BF21-463CFEE9B382}" Name="ID" DisplayName="Product ID"></FieldRef>
              <FieldRef ID="{36819A9B-E748-47D5-9949-A65DD195BF80}" Name="Descritpion" DisplayName="Product Description"></FieldRef>
            </ViewFields>
            <Query>
              <OrderBy>
                <FieldRef Name="ID"></FieldRef>
              </OrderBy>
            </Query>
            <ParameterBindings>
              <ParameterBinding Name="NoAnnouncements" Location="Resource(wss,noXinviewofY_LIST)" />
              <ParameterBinding Name="NoAnnouncementsHowTo" Location="Resource(wss,noXinviewofY_DEFAULT)" />
          g
    8h"@  </ParameterBindings>
          </View>
        </Views>
        <Forms>
          <Form Type="DisplayForm" Url="DispForm.aspx" SetupPath="pagesform.aspx" WebPartZoneID="Main" />
          <Form Type="EditForm" Url="EditForm.aspx" SetupPath="pagesform.aspx" WebPartZoneID="Main" />
          <Form Type="NewForm" Url="NewForm.aspx" SetupPath="pagesform.aspx" WebPartZoneID="Main" />
        </Forms>
      </MetaData>
    </List>

    我们在此文档中添加的内容为:

    1. 在ContentTypes元素中添加<ContentTypeRef ID="0x01001bc8deb250c04fa0bd7d541e4757c82a"></ContentTypeRef>,此处的ID必须与第二部中创建的内容模板中得ContentType的ID相同。
    2. 添加Fields集合元素
      <Fields>
            <Field ID="{5CD2C0C1-67AC-4F9E-BF21-463CFEE9B382}" Name=&qug 8h"@ot;ID" DisplayName="Product ID" Type="Number"></Field>
            <Field ID="{fa564e0f-0c70-4ab9-b863-0177e6ddd247}" Name="Title" DisplayName="Product Name" Type="Text"></Field>
            <Field ID="{36819A9B-E748-47D5-9949-A65DD195BF80}" Name="Description" DisplayName="Product Descritpion" Type="Text"></Field>
      < /Fields>
      此元素中得ID也必须与第二步中创建的ID相同。此处定义的为此列表中包含的列。
    3. 在两个Views元素中得ViewFields元素中添加
      <FieldRef ID="{5CD2C0C1-67AC-4F9E-BF21-463CFEE9B382}" Name="ID" DisplayName="Product ID"></FieldRef>
      < FieldRef ID="{36819A9B-E748-47D5-9949-A65DD195BF80}" Name="Descritpion" DisplayName="Product Description"></FieldRef>

    g 8h"@

    四、部署此项目,刷新网站即可看到我们自定义的列表;在网站设置中得,网站栏、网站内容类型也可以看到我们新建的栏和内容类型。

  • 相关阅读:
    如何实现LRU缓存淘汰算法
    排序算法(上)
    MySQL为什么有时候会选错索引?
    mysql开启慢查询——wamp
    普通索引和唯一索引,应该如何选择
    php开发常用插件
    mysql批量添加大量测试数据
    .text()设置文本,.html()设置html, .val()设置值的使用
    ajax .load()方法
    jquery学习笔记一之window.onload与$(document).ready()区别
  • 原文地址:https://www.cnblogs.com/jackljf/p/4768640.html
Copyright © 2011-2022 走看看