Код ниже с использованием обещаний jQuery в сочетании с обратными вызовами выполняет следующие действия:
- Сохраняет UUID группы на сервере, используя
storeGroupOnServer()
- Создает элемент DOM для группы, используя
createGroupDomNode()
- Создает дочерние элементы для каждого изображения, используя
createNewChildDomNode()
Как это можно записать более ровно (избегая вложения), используя .then()
?
groupPromise.done(function(fileGroupInfo) {
storeGroupOnServer(fileGroupInfo.uuid, function(groupid){
createGroupDomNode(groupid, function(groupnode){
$.each(arrayOfFiles, function(i, file) {
file.done(function(fileInfo) {
createNewChildDomNode(fileInfo.cdnUrl, groupnode);
});
});
});
});
});
Шаг 1: storeGroupOnServer ():
storeGroupOnServer = function(uuid, callback) {
$.post('saveGroup.php', {uuid:uuid},
function(data) {
callback(data.groupid);
},'json');
};
Шаг 2: createGroupDomNode ():
createGroupDomNode = function(groupid, callback) {
var cloner = $('#cloner');
var newnode = cloner.clone(true);
newnode.attr('id',groupid);
newnode.removeClass('hide');
cloner.after(newnode);
callback(newnode);
}
Шаг 3: createNewChildDomNode ():
function createNewChildDomNode(imgpath, groupdom){
imgnode = $('<img/>').attr('src',imgpath);
picnode = $('<picture/>').append(imgnode);
$(groupdom).first().prepend(picnode);
}