2012-09-17 171 views
3

我想用自定義方法擴展$ .Deferred.pipe,這樣我就可以縮短我的延期鏈了。

我目前擁有的代碼是這樣

getDeferredFileEntry() 
//returns a ($.Deferred) promise to resolve with a FileEntry object 
    .pipe(function(entry){ 
     //returns a promise to resolve with an object 
     //containing the contents of the file as text 
     //and a reference to the file's FileEntry 
     var def = $.Deferred(); 
     entry.getDeferredText() 
      .done(function(fileText){ 
       def.resolve({text:fileText, fileEntry:entry}); 
      }); 
     return def.promise(); 
    )} 
    .done(function(response){ 
     var text = response.text; 
     var fileEntry = response.fileEntry; 

     console.log(text); 
     //do something with the text 
     console.log(fileEntry); 
     //do something else with the file entry after finished reading from it 
     //e.g. deleting with something like fileEntry.remove(); 
    }); 

我想縮短,要

getDeferredFileEntry() 
    .read(
     //uses the FileEntry object resolved by getDeferredFileEntry 
     //to call an asynchronous fileEntry.read() *in the background* 
     //the contents are then passed to the callback taken from below 
     //returns promise to resolve with the fileEntry object for chaining 
     function callback(text){ 
      //do something with the text 
      console.log(text); 
     } 
    ) 
    .remove(
     function(fileEntry){ 
      //library call to remove fileEntry that read() promised 
     } 
    ) 

我與如何從getDeferredFileEntry()解決FileEntry的對象傳遞給自定義read()掙扎在背景中。任何意見,將不勝感激

+1

getDeferredFileEntry是如何定義的?它所返回的promise對象將需要修改以添加額外的read方法,否則您將不得不將新的read方法添加到所有promise對象。 –

回答

0

爲什麼不簡單地創建一些輔助方法,抽象出你的管道邏輯?

function getFileEntry() { 
    // Returns a promise resolved when your file entry is available 
} 

function getFileContents(entryPromise) { 
    return entryPromise.pipe(function(entry) { 
    return readFileEntry(entry); 
    }); 
} 

function readFileEntry(entry) { 
    var dfr = $.Deferred(); 

    // do whatever you have to do to read the file 
    // then call dfr.resolve(fileContents); 

    return dfr.promise(); 
} 

function removeFileEntry(entry) { 
    var dfr = $.Deferred(); 

    // do whatever you have to do to remove the file 
    // then call dfr.resolve(); 

    return dfr.promise(); 
} 

使用這些方法,你的代碼應該結束這樣看:

var fileEntry = getFileEntry(); 

readFileEntry(fileEntry).then(function(contents) { 
    // Do something with your file contents 
    removeFileEntry(fileEntry); 
}); 
0

我不認爲自定義方法將有很大的幫助,你仍然需要尊重鏈接(例如,通過維護一個內部隊列)。

在你的情況,嵌套回調是最簡單的事情:

getDeferredFileEntry().then(function(entry) { 
    return entry.getDeferredText().then(function(text) { 
    // after finished reading from it: 
     console.log(txt); // do something with the read text 
     console.log(fileEntry); // do something with the file entry 
     return fileEntry.remove(); // e.g. deleting it 
    }); 
}); 

如果您更願意使用管道解決方案,您可以將其簡化爲

.pipe(function(entry) { 
    return entry.getDeferredText().pipe(function(fileText) { 
     return {text:fileText, fileEntry:entry}; 
    }); 
}) 

...而不是手動構建Deferreds。