joh*_*jik 2 extension-methods google-chrome google-chrome-extension promise
我想要做的是创建一个 chrome 扩展,它使用promises创建新的、嵌套的、书签文件夹。
执行此操作的函数是chrome.bookmarks.create()。但是我不能只循环这个函数,因为 chrome.bookmarks.create 是异步的。我需要等到创建文件夹并获取其新 ID,然后再继续处理其子项。
承诺似乎是要走的路。不幸的是,我找不到使用异步调用及其自己的回调(如chrome.bookmarks.create)的最小工作示例。
我已经阅读了一些教程1、2、3、4。我已经搜索过 stackOverflow,但所有的问题似乎都不是关于 chrome 扩展库的普通承诺。
我不想使用插件或库:没有 node.js 或 jquery 或 Q 或其他。
我尝试按照教程中的示例进行操作,但很多事情没有意义。例如,教程指出:
promise 构造函数接受一个参数——一个带有两个参数的回调:resolve 和 reject。
但后来我看到这样的例子:
const wait = ms => new Promise(resolve => setTimeout(resolve, ms));
这是如何运作的对我来说是个谜。
另外,当它从未被定义时,你怎么能调用resolve()?教程中的示例似乎没有与现实生活中的代码相匹配。另一个例子是:
Run Code Online (Sandbox Code Playgroud)function isUserTooYoung(id) { return openDatabase() // returns a promise .then(function(col) {return find(col, {'id': id});})
我如何通过col,或得到任何结果!
因此,如果有人能给我一个带有自己回调的异步函数的 Promise 的最小工作示例,我将不胜感激。
所以想要代码,所以这是我的非工作尝试:
//loop through all
function createBookmarks(nodes, parentid){
var jlen = nodes.length;
var i;
var node;
for(var i = 0; i < nodes.length; i++){
var node = nodes[i];
createBookmark(node, parentid);
}
}
//singular create
function createBookmark(node, parentid){
var bookmark = {
parentId : parentid,
index : node['index'],
title : node['title'],
url : node['url']
}
var callback = function(result){
console.log("creation callback happened.");
return result.id; //pass ID to the callback, too
}
var promise = new Promise(function(resolve, reject) {
var newid = chrome.bookmarks.create(bookmark, callback)
if (newid){
console.log("Creating children with new id: " + newid);
resolve( createBookmarks(bookmark.children, newid));
}
});
}
//allnodes already exists
createBookmarks(allnodes[0],"0");
Run Code Online (Sandbox Code Playgroud)
只是不起作用。回调的结果始终是未定义的,这应该是,而且我看不到 Promise 对象如何改变任何东西。当我尝试使用 promise.then() 时,我同样感到困惑。
var newid = promise.then( //wait for a response?
function(result){
return chrome.bookmarks.create(bookmark, callback);
}
).catch(function(error){
console.log("error " + error);
});
if (node.children) createBookmarks(node.children, newid);
Run Code Online (Sandbox Code Playgroud)
同样,newid 总是未定义的,因为 bookmarks.create() 是异步的。
感谢您提供的任何帮助。
老实说,您应该只使用网络扩展 polyfill。手动承诺 chrome API 既浪费时间又容易出错。
如果你绝对坚持,这是你如何承诺chrome.bookmarks.create 的一个例子。对于其他 chrome.* API,您还必须拒绝回调的错误参数。
function createBookmark(bookmark) {
return new Promise(function(resolve, reject) {
try {
chrome.bookmarks.create(bookmark, function (result) {
if (chrome.runtime.lastError) reject(chrome.runtime.lastError)
else resolve(result)
})
} catch (error) {
reject(error)
}
})
}
createBookmark({})
.then(function (result) {
console.log(result)
}).catch(function (error) {
console.log(error)
})Run Code Online (Sandbox Code Playgroud)
要创建多个书签,您可以:
function createBookmarks(bookmarks) {
return Promise.all(
bookmarks.map(function (bookmark) {
return createBookmark(bookmark)
})
)
}
createBookmarks([{}, {}, {}, {}])
.catch(function (error) {
console.log(error)
})Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3131 次 |
| 最近记录: |