Sp.RequestExecutor.executeSyncを延期します
-
10-12-2019 - |
質問
ホストWebのリストの1つから情報をつかむために、SP.RequestExecutor.executeAsync()
を実行する必要があるSharePointアプリケーションに取り組んでいます。どのような方法がOData Callを呼び出しているかによって、私は何か異なります。
残念ながら、executor.executeAsync()
が$.ajax()
を使用し、の実行を実行するという点では、$.when().done()
が演奏していないので、非同期呼び出しが行われます。下記のコードは表示されている場合はいくつかのコードです。
load = function (){
$.when(getEntries()).done(function () {
ViewModels.Calendar.addEventSource(ko.utils.unwrapObservable(eventList));
});
}
getEntries = function () {
return executor.executeAsync({
url: appweburl
+ "/_api/SP.AppContextSite(@target)/web/lists/getbytitle('" + LIST + "')/items?@target='" + hostweburl
+ "'&$select=Title,OData__x006e_ot5,qnlu,OData__x0066_x20"
+ "&$filter=OData__x0066_x20 eq '" + ViewModels.Person.user.userName() + "' "
+ "and qnlu ge DateTime'" + startDate().toString("yyyy-MM-dd") + "T00:00:00' "
+ "and qnlu le DateTime'" + endDate().toString("yyyy-MM-dd") + "T00:00:00' ",
method: "GET",
headers: { "Accept": "application/json; odata=verbose" },
success: onGetEntriesSuccess,
error: onoDataCallFailure
});
},
onGetEntriesSuccess = function (data) {
var jsonObject = JSON.parse(data.body);
$.each(jsonObject.d.results, function (index, item) {
eventList.push(new Event(item.qnlu, item.OData__x006e_ot5));
});
},
onoDataCallFailure = function (data, errorCode, errorMessage) {
alert('Failed to get host site. Error:' + errorMessage);
};
.
どんな考え/提案も理解されます。
解決
新しい.deferredを作成します。Deferredを返します。通話から塗られたもの。Deferred.Resolveまたはdeferred.RejectをCocaと障害のあるハンドラに呼び出します。
他のヒント
スコットの答えにいくつかの詳細を追加するために、あなたはこのようなことをすることができます:
function load () {
var call = getEntries();
call.done(function (eventList) {
ViewModels.Calendar.addEventSource(ko.utils.unwrapObservable(eventList));
});
}
function getEntries () {
// create the deferred object
var def = new $.Deferred();
executor.executeAsync({
url: appweburl
+ "/_api/SP.AppContextSite(@target)/web/lists/getbytitle('" + LIST + "')/items?@target='" + hostweburl
+ "'&$select=Title,OData__x006e_ot5,qnlu,OData__x0066_x20"
+ "&$filter=OData__x0066_x20 eq '" + ViewModels.Person.user.userName() + "' "
+ "and qnlu ge DateTime'" + startDate().toString("yyyy-MM-dd") + "T00:00:00' "
+ "and qnlu le DateTime'" + endDate().toString("yyyy-MM-dd") + "T00:00:00' ",
method: "GET",
headers: { "Accept": "application/json; odata=verbose" },
success: onGetEntriesSuccess,
error: onoDataCallFailure
});
function onGetEntriesSuccess (data) {
var jsonObject = JSON.parse(data.body);
var eventList = [];
$.each(jsonObject.d.results, function (index, item) {
eventList.push(new Event(item.qnlu, item.OData__x006e_ot5));
});
// resolve the deferred object
// eventList will be passed as parameter to done
def.resolve(eventList);
}
function onoDataCallFailure (data, errorCode, errorMessage) {
// reject the deferred object
def.reject('Failed to get host site. Error:' + errorMessage);
}
// return the promise
return def.promise();
}
. 所属していません sharepoint.stackexchange