SharePoint Project Server List 列表CURD操作使用rest api接口
//#region 界面交互代码
var issuesUtils = issuesUtils || {};
(function () {
/**
* 点击问题提处理方案按钮事件
*/
issuesUtils.issuuesSchemeBtn = function () {
var item_id = commonUtils.getUrlParamValue('ID');
issuesList.getIssuesItem(item_id, function (data) {
console.log(JSON.stringify(data));
var issuesSchemeUrl = '/sites/pwa/Lists/List/AllItems.aspx?IssuesId=' + data.ID;
//location.href = issuesSchemeUrl;
}); issuesList.deleteItem(item_id, function (data) {
alert("删除成功");
});
};
})();
//#endregion //#region 问题list
/**
* issues list
*/
var issuesList = issuesList || {};
(function () { var projectSiteName = function () {
return location.pathname.replace('/', '').split('/')[2];
}; /**
* 获取列表项目
* @param {*} itemId
* @param {*} fun
*/
issuesList.getIssuesItem = function (itemId, fun) {
var server_url = '/sites/pwa/' + projectSiteName() + '/_api/Lists/IssuesList/items(' + itemId + ')';
commonUtils.executeRequest({
type: commonUtils.ExecuteRequestType.READ,
url: server_url,
callBack: function (data) {
if (fun) {
fun(data);
}
}
});
}; issuesList.addIssuesItem = function (callBack) {
var issuesData = {
__metadata: { type: 'SP.Data.IssuesListItem' },
Title: '我的测试问题1212'
};
var server_url = '/sites/pwa/' + projectSiteName() + '/_api/Lists/IssuesList/items';
commonUtils.executeRequest({
type: commonUtils.ExecuteRequestType.CREATE,
data: issuesData,
url: server_url,
callBack: function (data) { }
});
}; issuesList.updateItem = function (callBack) {
var server_url = '/sites/pwa/' + projectSiteName() + '/_api/Lists/IssuesList/items(6)';
var issuesData = {
__metadata: { type: 'SP.Data.IssuesListItem' },
Title: '修改标题111111111'
};
commonUtils.executeRequest({
type: commonUtils.ExecuteRequestType.UPDATE,
data: issuesData,
url: server_url,
callBack: function (data) { }
});
}; /**
* 删除问题
* @param {*ID} itemId
* @param {*} callBack
*/
issuesList.deleteItem = function (itemId, callBack) {
var server_url = '/sites/pwa/' + projectSiteName() + '/_api/Lists/IssuesList/items(' + itemId + ')';
commonUtils.executeRequest({
type: commonUtils.ExecuteRequestType.DELETE,
url: server_url,
callBack: callBack
});
}
})();
//#endregion //#region 问题处理方案list
var issuesSchemeList = issuesSchemeList || {};
(function () { })();
//#endregion //#region 常用工具类
/**
* 常用工具类
*/
var commonUtils = commonUtils || {};
(function () {
/**
* 根据参数名称获取URL参数值
* @param {参数名称} paramName
*/
commonUtils.getUrlParamValue = function (paramName) {
var reg = new RegExp("(^|&)" + paramName + "=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if (r != null) return unescape(r[2]);
return undefined;
}; /**
*
* @param {type:commonUtils.ExecuteRequestType,data:提交的数据对象,url:rest api url 地址,callBack:回调函数function(data){}} option
*/
commonUtils.executeRequest = function (option) {
var ajax_type = undefined;
var ajax_header = undefined;
var ajax_data = undefined;
switch (option.type) {
case commonUtils.ExecuteRequestType.CREATE:
//添加数据
ajax_type = 'POST';
ajax_header = {
"Accept": "application/json; odata=verbose",
"X-RequestDigest": $("#__REQUESTDIGEST").val()
};
break;
case commonUtils.ExecuteRequestType.UPDATE:
//修改数据
ajax_type = 'POST';
ajax_header = {
"Accept": "application/json; odata=verbose",
"X-RequestDigest": $("#__REQUESTDIGEST").val(),
"IF-MATCH": "*",
"X-HTTP-Method": "MERGE"
};
break;
case commonUtils.ExecuteRequestType.READ:
//读取数据
ajax_type = 'GET';
ajax_header = {
"Accept": "application/json; odata=verbose",
};
break;
case commonUtils.ExecuteRequestType.DELETE:
//删除数据
ajax_type = 'POST';
ajax_header = {
//"Accept": "application/json; odata=verbose",
"X-RequestDigest": $("#__REQUESTDIGEST").val(),
"IF-MATCH": "*",
"X-HTTP-Method": "DELETE"
};
break;
}
if (option.data) {
ajax_data = JSON.stringify(option.data);
}
if (ajax_header && ajax_header) {
$.ajax({
url: option.url,
type: ajax_type,
//contentType: "application/json;odata=verbose",
data: ajax_data,
headers: ajax_header,
complete: function (xhr, textStatus) {
if (xhr.status == 200) {
var jsondata = xhr.responseText ? JSON.parse(xhr.responseText).d : {};
if (option.callBack) {
option.callBack(jsondata);
}
} else {
console.error("出现错误,错误代码为" + xhr.status);
}
},
error: function (data, errorCode, errorMessage) {
console.error("出现错误:" + errorMessage);
}
});
} else {
console.error("调用commonUtils.executeRequest方法参数不合法");
}
} /**
* 调用rest api类型,增删改查
*/
commonUtils.ExecuteRequestType = {
CREATE: 1,
UPDATE: 2,
READ: 3,
DELETE: 4
};
})();
//#endregion
SharePoint Project Server List 列表CURD操作使用rest api接口的更多相关文章
- Sharepoint/Project Server 看不到“安全性”菜单以及子菜单
在Sharepoint/Project Server 构建后,左侧看不到看不到“服务器设置”菜单,在设置菜单后左侧出现“服务器设置”菜单,但是依然在右侧看不到“安全性”菜单以及子菜单. (这个图是借的 ...
- 创建包含CRUD操作的Web API接口2:实现Get方法
本节是前一节的延续,上一节中我们已经为我们的Web API项目创建必要的基础设施. 在本节中,我们将在我们的控制器类中实现操作方法,这些方法用来处理HTTP GET请求. 根据Web API命名约定, ...
- 创建包含CRUD操作的Web API接口-第一部
在这里,我们将创建一个新的Web API项目,它将使用实体框架实现Get,POST.PUT和DELETE方法来实现CRUD操作. 首先,在Visual Studio 2013 for Web expr ...
- 创建包含CRUD操作的Web API接口5:实现Delete方法
本节是前面四节的延续,在前面几节中我们创建了Web API并添加了必要的基础设施,实现了Get.Post.和Put方法.本节中,我们将介绍如何在Web API中实现Delete方法. 在RESTful ...
- 创建包含CRUD操作的Web API接口4:实现Put方法
本节教程是前三节的延续,在前面我们创建了Web API和必要的基础设施,也实现了Get和Post方法.接下来,我们将在Web API中实现Put方法. RESTful架构中,HTTP PUT方法用于在 ...
- 创建包含CRUD操作的Web API接口3:实现Post方法
本节是前面两节的延续,前面我们为Web API创建了必要的基础设施,并实现了Get方法.在这里,我们将在Web API中实现POST方法. 在RESTful架构中,使用HTTP POST请求用来在数据 ...
- Javascript操作DOM常用API总结
基本概念 在讲解操作DOM的api之前,首先我们来复习一下一些基本概念,这些概念是掌握api的关键,必须理解它们. Node类型 DOM1级定义了一个Node接口,该接口由DOM中所有节点类型实现.这 ...
- JavaScript 操作 DOM 常用 API 总结
文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认识. 基本概念 在讲解操作DOM的api之前, ...
- 【repost】Javascript操作DOM常用API总结
Javascript操作DOM常用API总结 文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认 ...
随机推荐
- mysql 大数据 查询方面的测试
---方法1: 直接使用数据库提供的SQL语句---语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 LIMIT M,N---适应场景: 适用于数据量较少的情况(元组百/千 ...
- 提供的STC89C52RC单片机GPS在LCD1602液晶只显示welcome to use问题?
1.使用USB-TTL接GPS单独测试GPS定位在所处环境看是否能定位到. 2.检查自己使用的单片机是不是STC89C52RC型号,提供例程使用的这个型号单片机.如果使用其他51单片机,请先使用STC ...
- putty screen
http://www.cnblogs.com/xupeizhi/archive/2013/05/20/3088779.html screen 会创建一个跑着shell的单一窗口 Ctrl+a d退出刚 ...
- poj 1328 Radar Installatio【贪心】
题目地址:http://poj.org/problem?id=1328 Sample Input 3 2 1 2 -3 1 2 1 1 2 0 2 0 0 Sample Output Case 1: ...
- SDUT 1048 Digital Roots
Digital Roots Time Limit: 1000ms Memory limit: 65536K 题目描述 The digital root of a positive integer ...
- 算法(Algorithms)第4版 练习 2.2.11(3)
关键代码实现: public static void sort(Comparable[] input) { int N = input.length; aux = input.clone();//mu ...
- Spark- Transformation实战
RDD的算子分为两类,是 Trans formation(Lazy),一类是 Action(触发任务执行RDD不存在真正要计算的数据,而是记录了RDD的转换关系(调用了什么方法,传入什么函数) RDD ...
- HDU 4714 Tree2cycle:贪心
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4714 题意: 给你一棵树,添加和删除一条边的代价都是1.问你将这棵树变成一个环的最小代价. 题解: 贪 ...
- node.js抓取网上图片保存到本地
用到两个模块,http和fs var http = require("http");var fs = require("fs"); var server = h ...
- 原生js图片懒加载特效
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...