Sharepoint2010之父子表实现
在Sharepoint的实际运用中会经常使用到父子表来建立2个表之间的关系。通常父表为表头,存储公共的数据项目,子表存储细分的项目。
例如通过下面2个表实现图书借阅功能,表1为图书的基础信息,表2为图书的借阅记录,采用查阅字段调用表一的图书数据。
1、先建一个自定表,字段如表1所示。
表1 图书表
2、再建个自定义表,增加查阅字段
表2 图书借阅记录字段如下
3、打开建好的表一,新建一条记录,如下所示
4、选择列表的数据,点击菜单上的“自定义表单”,调用Infopath2010对表单进行定制.
调整后的表单如下
图书编号希望采用自动编号功能,编号规则 TS+4位年号+3位序号。序号采用列表ID。增加数据源,采用图书表作为数据源。
图书编号的属性里增加公式如下,ID为插入辅助数据源的域“ID”。预览一下,可以正常显示了。
5、回到表1图书表的列表,选择上面菜单“表单web部件”,选择“显示窗体”。
选择添加web部件,如下所示,添加图书借阅记录表。
建立2表的连接,点击web部件右上角的小三角,数据发送对象,选择图书借阅记录,配置连接
完成后选择右上角的停止编辑。点击表一 图书表的列表项目,可以看到效果如下。点击添加记录,可以增加借阅记录。
6、此方法添加项目,需要手动选择主表的编号,不太方便而且容易出错。下面对表2进行如下改造。用Infopath编辑表2的表单,新建一个字段ID1,用于存储主表ID。
ID1增加一条规则,当ID1不为空时,设置图书编号=ID1
图书编号 增加一条格式规则。当图书编号不为空时,禁用此控件。
7、上传表单到服务器后,进入表2 的表单web部件,(项目)新窗体。向窗体web部件增加一个查询字段URL筛选器
配置筛选器,筛选字段填写 ID1,停止编辑。配置筛选器web的连接,选择ID1
8、测试一下 ,浏览器填写表2的新建项目的连接地址 newifs.aspx?ID1=1 ,实现了通过URL传递参数,效果如下。
9、回到表1,打开表1的表单web部件,显示窗体,添加web部件,选择内容编辑器,编辑HEML源代码。
添加以下jqurey代码,由于本例采用jqurey,需要集成到Sharepoint内,可参考以下方法集成。
http://www.cnblogs.com/Sunmoonfire/archive/2012/07/27/2612510.html
代码如下,获取表1的ID,生成表2的带传递ID参数的地址。
<script type="text/jscript"> function test()
{
var tt=document.aspnetForm.attributes["action"].value;
var arr=new Array();
arr=tt.split('&');
var ID1=arr[1].substring(3,10);
var url1 = "http://列表地址/Item/newifs.aspx?ID1="+ ID1;
return url1;
}
function openModalDialog()
{
var UURL=test();
NewItem2(event,UURL);
}</script>
10、用 SharePoint Designer 2010 编辑表1的项目显示窗体
点击添加新项目
点击下面的标记的小三角,编辑标记
粘贴下面的代码
<a class="ms-addnew" href="#" onclick="javascript:openModalDialog();javascript:return false;" target="_self">
保存后退出SPD。至此,大功告成。
先填写表一,填写后,打开表一的项目,添加新项目,添加子表项目。
效果如下
Sharepoint2010之父子表实现的更多相关文章
- JS组件系列——表格组件神器:bootstrap table(二:父子表和行列调序)
前言:上篇 JS组件系列——表格组件神器:bootstrap table 简单介绍了下Bootstrap Table的基础用法,没想到讨论还挺热烈的.有园友在评论中提到了父子表的用法,今天就结合Boo ...
- mybatis父子表批量插入
<!--父子表批量插入 --> <insert id="insertBatch" parameterType="com.niwopay.dto.beni ...
- bootstrap-table 父子表入门篇
官方文档:http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/#多语言 一.引入js.css <!-- 引入bootstrap ...
- mysql 父子表 注意事项
今天遇到一个问题,父子表关联查询时总是多出几条数据,后来排查是父子关系的字段 类型不一致导致的
- SQL 父子表,显示表中每条记录所在层级
1.sqlserer 中有一张父子关系表,表结构如下: CREATE TABLE [dbo].[testparent]( [ID] [int] IDENTITY(1,1) NOT NULL, [nam ...
- 05mycat父子表
表连接的难题在mycat中是不允许跨分片做表连接查询的 创建t_orders表 create table t_orders( id int PRIMARY key, customer_id int n ...
- sql父子表结构,常用脚本
在实际运用中经常会创建这样的结构表Category(Id, ParentId, Name),特别是用于树形结构时(菜单树,权限树..),这种表设计自然而然地会用到递归,若是在程序中进行递归(虽然在程序 ...
- DevExpress中GridColumnCollection实现父子表数据绑定
绑定数据: 父表: DataTable _parent = _dvFlt.ToTable().Copy(); 子表: DataTable _child = _dvLog.ToTable().Copy( ...
- bootstrap-table 实现父子表
1.引入相关的css和js <link type="text/css" href="/components/bootstrap/3.3.7/css/bootstra ...
随机推荐
- codeforces 630B Moore's Law
B. Moore's Law time limit per test 0.5 seconds memory limit per test 64 megabytes input standard inp ...
- javascript判断NaN
功能: isNaN() 函数用于检查其参数是否是非数字值. 语法: isNaN(x) x 必需.要检测的值. 返回值: 如果 x 是特殊的非数字值 NaN(或者能被转换为这样的值),返回的值就是 tr ...
- HDU 5776 sum (思维题)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5776 题目让你求是否有区间的和是m的倍数. 预处理前缀和,一旦有两个数模m的值相同,说明中间一部分连续 ...
- android 脸部抠图
原帖:http://www.eoeandroid.com/thread-205445-1-1.html package com.face; import android.app.Activity; i ...
- ID生成器详解
概述 ID 生成器也叫发号器,它的主要目的就是"为一个分布式系统的数据object产生一个唯一的标识",但其实在一个真实的系统里可能也可以承担更多的作用.概括起来主要有以下几点: ...
- C#学习笔记(十六):Attribute
Attribute可以为类或方法添加一些附加的信息,我们可以看看MSDN对Attribute的描述: 公共语言运行时允许你添加类似关键字的描述声明,叫做attributes, 它对程序中的元素进行标注 ...
- c# 实现IComparable、IComparer接口、Comparer类的详解
在默认情况下,对象的Equals(object o)方法(基类Object提供),是比较两个对象变量是否引用同一对象.我们要必须我自己的对象,必须自己定义对象比较方式.IComparable和ICom ...
- C++中void型指针
问题由来: PX_FORCE_INLINE void* operator new(size_t size, const char* handle, const char * filename, int ...
- [Android][Android Studio] *.jar 与 *.aar 的生成与*.aar导入项目方法
主要讲解Android Studio中生成aar文件以及本地方式使用aar文件的方法. 在Android Studio中对一个自己库进行生成操作时将会同时生成*.jar与*.aar文件. 分别存储位置 ...
- 数据挖掘十大经典算法(9) 朴素贝叶斯分类器 Naive Bayes
贝叶斯分类器 贝叶斯分类器的分类原理是通过某对象的先验概率,利用贝叶斯公式计算出其后验概率,即该对象属于某一类的概率,选择具有最大后验概率的类作为该对象所属的类.眼下研究较多的贝叶斯分类器主要有四种, ...