Blog链接:https://blog.51cto.com/13969817
创新互联是一家从事企业网站建设、成都做网站、成都网站设计、行业门户网站建设、网页设计制作的专业网站设计公司,拥有经验丰富的网站建设工程师和网页设计人员,具备各种规模与类型网站建设的实力,在网站建设领域树立了自己独特的设计风格。自公司成立以来曾独立设计制作的站点数千家。
我们使用SharePoint Hosted App获取用户ID时,你将发现SharePoint中的JavaScript Object Model(JSOM)比REST API更容易使用。
REST Protocol的第一个限制是它只返回100个条目,我还没有找到一个方法来增加这个,而使用JSOM可以获取所有用户的列表,并按照ID 排序。
比如我们需要list来保存User ID,然后分别使用REST API和JSOM获取用户列表的代码。
function getUsers() {
var pUrl = _spPageContextInfo.webAbsoluteUrl + "/_api/site/rootweb/lists/getByTitle('User Information List')/items?$orderby=Id";
//var pUrl = _spPageContextInfo.webAbsoluteUrl + "/_api/site/rootweb/lists/getByTitle('User Information List')/items?$orderby=Id&$select=Id,Title,Name,EMail";
$.ajax(pUrl, { method: "GET", headers: { "accept": "application/json;odata=verbose" } }).done(storeUsers).fail(getUserError);
}
function storeUsers(data) {
var responseParse = JSON.parse(data.body);
user_list = responseParse.d.results;
}
function getUserError(jqXHR, textStatus) {
alert(textStatus);
}
function getAllUsers() {
var userInfoList = context.get_site().get_rootWeb().get_siteUserInfoList();
var camlQuery = new SP.CamlQuery();
camlQuery.set_viewXml('
userListItemCollection = userInfoList.getItems(camlQuery);
context.load(userListItemCollection);
//context.load(userListItemCollection, 'Include(Title,ID,Name,EMail)');
context.executeQueryAsync(onGetAllUsersSuccess, onGetAllUsersFail);
}
function onGetAllUsersSuccess() {
var userArr = [];
var arrNames = [];
var listEnumerator = userListItemCollection.getEnumerator();
while (listEnumerator.moveNext()) {
var oList = listEnumerator.get_current();
//avoid duplicates
var index = $.inArray(oList.get_item('Title'), arrNames);
if (index == -1) {
userArr.push({
Id: oList.get_item('ID'),
Title: oList.get_item('Title'),
Name: oList.get_item('Name'),
EMail: oList.get_item('EMail')
});
arrNames.push(oList.get_item('Title'));
}
}
user_list = userArr;
}
function onGetAllUsersFail(sender, args) {
alert("Unable to load user information: " + args.get_message());