通过JSOM获取当前用户更改的项目

时间:2015-01-30 10:13:07

标签: javascript sharepoint-2013 csom

在SharePoint 2013 JavaScript中,我想从列表中加载已由当前用户修改的所有项目。我试过这个:

var ctx = SP.ClientContext.get_current();
var settings = ctx.get_web().get_lists().getByTitle('My Setting List');

var settingQuery = new SP.CamlQuery();
settingQuery.set_viewXml('<Query><Where><Eq><FieldRef Name="Editor" LookupId="TRUE" /><Value Type="Integer"><UserID /></Value></Eq></Where></Query>');
var settingItems = settings.getItems(settingQuery);

ctx.load(settingItems, 'Include(Id, Title)');
ctx.executeQueryAsync( /* ... */ );

但它给了我所有用户的所有项目。我做错了什么?

1 个答案:

答案 0 :(得分:1)

SP.CamlQuery.viewXml Property期望以下列格式指定XML模式:

<View>
   <Query>
      ...
    </Query>
</View>

因此,解决方案是使用View元素包围您的查询。

示例

var ctx = SP.ClientContext.get_current();
var list = ctx.get_web().get_lists().getByTitle(listTitle);
var qry = new SP.CamlQuery();
qry.set_viewXml('<View><Query><Where><Eq><FieldRef Name="Editor" LookupId="TRUE" /><Value Type="Integer"><UserID /></Value></Eq></Where></Query></View>');
var items = list.getItems(qry);

ctx.load(items, 'Include(Id, Title)');
ctx.executeQueryAsync( 
      function() {
         console.log(items.get_count());
      },
      function(sender,args){
         console.log(args.get_message());
      });