最近有几个朋友问到了有关自定义字段类型的问题,为了让更多的人了解自定义字段类型的方法,特写一篇博客与大家分享,首先看一下解决方案目录

创建自定义类型分以下几个步骤:

第一步:添加SharePoint映射文件夹Xml,在Xml的文件名必须以fldtypes_开头,否则不能识别,为了更好的了解Xml里面的结构我们可以在服务器上打开,看一看系统是如何定义的。

第二步:开始省市定义联动,XML定义

<?xml version="1.0" encoding="utf-8" ?>
<FieldTypes>
<FieldType>
<Field Name="TypeName">ProvinceCityArea</Field>
<Field Name="ParentType">Text</Field>
<Field Name="TypeDisplayName">Province City Area</Field>
<Field Name="TypeShortDescription">省市区联动</Field>
<Field Name="UserCreatable">TRUE</Field>
<Field Name="FieldTypeClass">
SharePointProject_Custom_FieldsType_Controls.Controls.ProvinceCityArea,
$SharePoint.Project.AssemblyFullName$
</Field>
</FieldType>
<FieldType>
<Field Name="TypeName">ProvinceCity</Field>
<Field Name="ParentType">Text</Field>
<Field Name="TypeDisplayName">Province City</Field>
<Field Name="TypeShortDescription">省市联动</Field>
<Field Name="UserCreatable">TRUE</Field>
<Field Name="FieldTypeClass">
SharePointProject_Custom_FieldsType_Controls.Controls.ProvinceCity,
$SharePoint.Project.AssemblyFullName$
</Field>
</FieldType>
</FieldTypes>

第三步:创建ProvinceCityControl 类文件,并继承 BaseFieldControl,省市的数据来源是另一张表

代码主要重载 protected override void CreateChildControls()

using System.Web.UI;
using System.Web.UI.WebControls;
using Microsoft.SharePoint;
using Microsoft.SharePoint.WebControls; namespace SharePointProject_Custom_FieldsType_Controls.Controls
{
public class ProvinceCityControl : BaseFieldControl
{
private DropDownList _ddlProvince;
private DropDownList _ddlCity;
private SPWeb _web;
private SPListCollection _listCollection;
private SPList _list;
private SPQuery _query;
private SPListItemCollection _listItemCollection; protected override void CreateChildControls()
{
if (this.ControlMode == SPControlMode.Display)
{
this.Controls.Add(new LiteralControl("" + this.Value));
}
else
{
_ddlProvince = new DropDownList();
_ddlCity = new DropDownList();
using (_web = SPContext.Current.Web)
{
_listCollection = _web.Lists;
_list = _listCollection.TryGetList(Consts.LIST_DICTIONARY);
if (_list != null)
{
#region Province
_query = new SPQuery();
_query.Query = string.Concat(
"<Where>",
"<Eq><FieldRef Name='Group_x003a_Title'/><Value Type='Lookup'>" + Consts.GROUP_PROVINCE + "</Value></Eq>",
"</Where>"
);
_query.ViewFields = string.Concat(
"<FieldRef Name='DictionaryName'/>",
"<FieldRef Name='Title'/>"
);
_listItemCollection = _list.GetItems(_query);
_ddlProvince.AutoPostBack = true;
_ddlProvince.SelectedIndexChanged += new EventHandler(Province_SelectedIndexChanged);
foreach (SPListItem item in _listItemCollection)
{
_ddlProvince.Items.Add(new ListItem(item["DictionaryName"].ToString(), item["Title"].ToString()));
}
#endregion #region City
LoadCity();
#endregion } }
this.Controls.Add(_ddlProvince);
this.Controls.Add(new LiteralControl("-"));
this.Controls.Add(_ddlCity);
}
} #region Province of autoPostBack
void Province_SelectedIndexChanged(object sender,EventArgs e)
{
LoadCity();
}
#endregion #region Load City
void LoadCity()
{
_ddlCity.Items.Clear();
_query = new SPQuery();
_query.Query = string.Concat(
"<Where><And>",
"<Eq><FieldRef Name='Group_x003a_Title'/><Value Type='Lookup'>" + Consts.GROUP_CITY + "</Value></Eq>",
"<BeginsWith><FieldRef Name='Title'/><Value Type='Text'>" + _ddlProvince.SelectedValue.ToString() + "</Value></BeginsWith>",
"</And></Where>"
);
_listItemCollection = _list.GetItems(_query);
foreach (SPListItem item in _listItemCollection)
{
_ddlCity.Items.Add(new ListItem(item["DictionaryName"].ToString(), item["Title"].ToString()));
}
}
#endregion public override object Value
{
get
{
return base.Value;
}
set
{
base.Value = value;
}
}
}
}

第四步:再创建一个类ProvinceCity ,并继承SPFieldText

using Microsoft.SharePoint;
using Microsoft.SharePoint.WebControls; namespace SharePointProject_Custom_FieldsType_Controls.Controls
{
public class ProvinceCity:SPFieldText
{
public ProvinceCity(SPFieldCollection fields, string fieldName) : base(fields, fieldName) { }
public ProvinceCity(SPFieldCollection fields, string fieldType, string displayName) : base(fields, fieldType, displayName) { } public override BaseFieldControl FieldRenderingControl
{
get
{
BaseFieldControl fc = new ProvinceCityControl();
fc.FieldName = this.InternalName;
return fc;
}
}
}
}

如果要设置默认值请Override DefaultValue,如果要验证格式是否正确 请Override GetValidatedString

第五步:部署查看效果

第六步:创建栏查看效果

就这么简单,完成了,快来试吧。

分类: SharePoint

转载:SharePoint 2010 自定义 字段 类型--------省市区联动的更多相关文章

  1. SharePoint 2010 自定义 字段 类型--------省市区联动

    转:http://www.cnblogs.com/sp007/p/3384310.html 最近有几个朋友问到了有关自定义字段类型的问题,为了让更多的人了解自定义字段类型的方法,特写一篇博客与大家分享 ...

  2. [SharePoint 2010] 自定义字段类型开发(二)

    在SharePoint 2010中实现View Action Button效果. http://www.sharepointblogs.be/blogs/vandest/archive/2008/06 ...

  3. sharepoint2010问卷调查(3)-实现问卷的开始和结束时间(采用自定义字段类型)

    接着上面的图片调查,sharepoint自带的问卷调查是没有开始和结束时间的.这个在项目过程不太实用.问卷一般有开始和结束时间的.因此需要自己 动手开发一个自定义字段类型字段.如下图: 开发添加栏目会 ...

  4. 开发MOSS自定义字段类型

    前段时间,由于刚好项目定制的需要,笔者就开发了几个自定义字段类型.在这抽空做个详细笔记,方便初学者学习.这方面的资料也很多,如果自身觉得不大明白可以参考下SDK和网上的相关文章.本章的目的主要是给新手 ...

  5. sharepoint2010问卷调查(2)-实现问卷的图片调查(采用自定义字段类型)

    1. 首先建立个图片库上传图片 并建立文件夹1和2,1下有1.1文件夹,2下2.1文件夹,2.1下有文件夹2.1.1. 在1文件夹下放如下图片: 2.建立自定义字段类型,如下图: 3.部署后建立栏目的 ...

  6. SharePoint 2010 ——自定义上传页面与多文件上传解决方案

    最近项目遇到一个很麻烦的问题,原以为很容易解决,结果搞了那么久,先开个头,再慢慢写 SharePoint 2010 ——自定义上传页面与多文件上传解决方案 1.创建Sharepoint空白项目,创建应 ...

  7. 转载-SharePoint 2010 WebPart与Google地图系列 一:创建显示地图的WebPart

    [原] SharePoint 2010 WebPart与Google地图系列 一:创建显示地图的WebPart 摘要: 作为信息化先驱的产品SharePoint 2010竟然对GIS相关技术支持如此有 ...

  8. sharepoint 2010自定义访问日志列表设置移动终端否和客户端访问系统等计算列的公式

    上个月本人开发和上线了一个在SharePoint 2010上基于HTML5的移动OA网站,后端服务采用自定义的基于AgilePoint工作流引擎的Sharepoint Web服务,前端主要采用Jque ...

  9. SharePoint 2010自定义母版页小技巧——JavaScript和CSS引用

    通常在我们的项目中,都会涉及到母版页的定制.并且必不可少的,需要配合以一套自己的JavaScript框架和CSS样式.你有没有遇到过这样的情况呢,在开发环境和UAT时都还算顺利,但是当最终部署到生产服 ...

随机推荐

  1. 05 redis中的Setbit位图法统计活跃用户

    一:场景=>>>长轮询Ajax,在线聊天时,能够用到 Setbit 的实际应用 场景: 1亿个用户, 每个用户 登陆/做任意操作 ,记为 今天活跃,否则记为不活跃 每周评出: 有奖活 ...

  2. CentOS Python 安装MySQL-python

    一.安装mysql yum list | grep mysql >>yum install -y mysql-server mysql mysql-devel CentOS 7的yum源中 ...

  3. leetCode 88.Merge Sorted Array (合并排序数组) 解题思路和方法

    Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array. Note: Y ...

  4. MongoDB 基本操作具体解释

    MongoDB 最大的特点是他支持的查询语言很强大,其语法有点类似于面向对象的查询语 言.差点儿能够实现类似关系数据库单表查询的绝大部分功能,并且还支持对数据建立索引. 最后因为 MongoDB 能够 ...

  5. python 基础 1.2--pycharm 的安装及使用

    一. windows 先安装pycharm. PyCharm是一种Python IDE,带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具,其提供了一个带编码补全,代码片段,支持代码折 ...

  6. TensorFlowSharp

    https://github.com/migueldeicaza/TensorFlowSharp

  7. P3382 【模板】三分法

    题目描述 如题,给出一个N次函数,保证在范围[l,r]内存在一点x,使得[l,x]上单调增,[x,r]上单调减.试求出x的值. 输入输出格式 输入格式: 第一行一次包含一个正整数N和两个实数l.r,含 ...

  8. 【BZOJ3956】Count 主席树+单调栈

    [BZOJ3956]Count Description Input Output Sample Input 3 2 0 2 1 2 1 1 1 3 Sample Output 0 3 HINT M,N ...

  9. 【BZOJ4197】[Noi2015]寿司晚宴 状压DP+分解质因数

    [BZOJ4197][Noi2015]寿司晚宴 Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴 ...

  10. 详解Vue 实例中的生命周期钩子

    Vue 框架的入口就是 Vue 实例,其实就是框架中的 view model ,它包含页面中的业务处理逻辑.数据模型等,它的生命周期中有多个事件钩子,让我们在控制整个Vue实例的过程时更容易形成好的逻 ...