添加自定义字段类

网站栏已经为一般用户和开发者提供了非常好的可重用的能力。更进一步,你可以定义一个可重用的栏定义,这将为我们带来更大的灵活性。配合Microsoft SharePoint Foundation 2010,你可以将创建自定义字段类型的门槛降得很低。

下面是创建一个自定义字段类型的总体步骤。你也可以参考这个msdn How to Video 视频

创建一个自定义字段控件的过程为:

1. 创建一个public 的自定义字段类型的类,并继承自某个内置的字段类型类,比如SPFieldBoolen,SPFieldChoice,或 SPFieldText。
2. 创建两个public的构造器,接收特定的参数,并传递给相同参数的父类的构造器。

3. 创建一个XML文件,作为该字段类型的部署文件。你必须将其部署到一个指定的目录中,并且需要在场级别激活该自定义字段类型。

创建自定义字段类

你必须把自定义字段类定义为public的,并且为其提供两个非默认的构造器。本例同时还展示了如何通过覆写GetValidatedString方法使用正则表达式验证字段的值。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.SharePoint;
  
namespace WingtipCustomFields {
public class ProductCode : SPFieldText {
  
public ProductCode(SPFieldCollection fields, string fName) : base (fields, fName) { }
public ProductCode(SPFieldCollection fields, string tName, string dName) : base (fields, tName, dName) { }
  
public override string DefaultValue {
get { return “P001″; }
}
  
public override string GetValidatedString( object value) {
  
if (!value.ToString().StartsWith(“P”))
  
{ throw new SPFieldValidationException(“Product code must start with ‘P’”); }
  
if (value.ToString().Length != 4)
  
{ throw new SPFieldValidationException(“Product code must be 4 chars”); }
  
// 在写入内容数据库前总是转换成大写的
return value.ToString().ToUpper();
}
}}

 

创建该字段类型的部署文件

字段类型的部署文件包含了由 Collaborative Application Markup Language (CAML) 定义的自定义字段类型。你必须以这样的格式命名该文件 fieldtypes*.xml 并将其部署到14\TEMPLATE\XML 目录下。下面的例子文件被命名为 fldtypes_WingtipCustomFields.xml。

1
2
3
4
5
6
7
8
9
10
11
12
13
< FieldTypes >
   < FieldType >
     < Field Name = "TypeName" >ProductCode</ Field >
     < Field Name = "ParentType" >Text</ Field >
     < Field Name = "TypeDisplayName" >Product Code</ Field >
     < Field Name = "TypeShortDescription" >Wingtip Product Code</ Field >
     < Field Name = "UserCreatable" >TRUE</ Field >
     < Field Name = "FieldTypeClass" >
       WingtipCustomFields.ProductCode,
       $SharePoint.Project.AssemblyFullName$ 
    </ Field >
   </ FieldType >
</ FieldTypes >

注意 -

Microsoft Visual Studio 2010 中的SharePoint部署工具允许你使用 $SharePoint.Project.AssemblyFullName$ 占位符来表示实际的组件名称。当你编译源文件并打包成解决方案包时SharPoint会用实际的组件名称替换该占位符。

转载于:https://www.cnblogs.com/hayden/archive/2011/12/14/2287690.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值