Chiamando SP.ClientContext in un loop JavaScript
-
10-12-2019 - |
Domanda
Sto loopando attraverso un numero di siti per eseguire una query che controlla se è stato aggiunto un nuovo contenuto alle librerie di documenti in quel sito nei tre giorni precedenti.Tuttavia, sto avendo problemi.Quando arrivo alla callback del successo, è sempre nell'ultima libreria DOC, il contesto del sito in quell'elenco.C'è qualcosa che mi manca qui?
var queryItems = function(myContext, myDocName, mySelector){
function getNewContent(x, y, z) {
var myContext = x,
myDocName = y,
mySelector = z;
function success() {
if( items.get_count() > 0 ) {
$(mySelector).find(".newContent").show();
}
}
function fail() {
console.log("Failed loading new content");
}
var myCtx = new SP.ClientContext(myContext),
myList = myCtx.get_web().get_lists().getByTitle(myDocName),
myQuery = new SP.CamlQuery(),
date = new Date(),
ISODate = ISODateString(new Date( date.getFullYear(), date.getMonth(), date.getDate() - 3 ) );
myQuery.set_viewXml('<View><Query><Where><Gt><FieldRef Name="Created" /><Value Type="DateTime">' + ISODate + '</Value></Gt></Where></Query></View>');
this.items = myList.getItems(myQuery);
myCtx.load( this.items );
myCtx.executeQueryAsync(Function.createDelegate(this, success), Function.createDelegate(this, fail));
};
return getNewContent(myContext, myDocName, mySelector);
}
for ( var obj in objDocLibs) {
(function(datum, sel) {
queryItems(context, datum, sel);
})(objDocLibs[obj].name, selector)
}
}
. Soluzione
Sono riuscito a far funzionare questa operazione con promesse, codice seguente:
var queryItems = function(myContext, myDocName, mySelector) {
var dfd = $.Deferred( function() {
var inContxt = myContext,
inDoc = myDocName,
myCtx = new SP.ClientContext(inContxt),
myList = myCtx.get_web().get_lists().getByTitle(inDoc),
myQuery = new SP.CamlQuery(),
date = new Date(),
ISODate = ISODateString(new Date( date.getFullYear(), date.getMonth(), date.getDate() - 3 ) );
myQuery.set_viewXml('<View><Query><Where><Gt><FieldRef Name="Created" /><Value Type="DateTime">' + ISODate + '</Value></Gt></Where></Query></View>');
var items = myList.getItems(myQuery);
myCtx.load( items );
myCtx.executeQueryAsync(
function() {
var itemCount = items;
dfd.resolve(itemCount);
},
function() {
dfd.reject(args.get_message());
}
);
});
return dfd.promise();
};
for ( var obj in objDocLibs) {
(function(datum, sel, con) {
queryItems(con, datum.name, sel).done( function(myItems) {
if( myItems.get_count() > 0 ) {
$(sel).find(".newContent").show();
}
});
})(objDocLibs[obj], selector, context)
}
. Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a sharepoint.stackexchange