1

我正在尝试遍历书签树(分类为文件夹和子文件夹),并使用它们的“路径”为每个文件夹创建标签列表,例如 - 存储在“开发”>“JS”>“中的书签博客的标签将映射为['Dev, 'JS, 'Blogs']

该结构的 Chrome 的默认结构 using chrome.bookmarks.getTree,如下所示:

[{
    'title' : '',
    children : [{
           'title' : 'a title',
           'url' : 'http://www.example.com'
       },
       {
           'title' : 'a folder category',
           'children' : [{...}]
        },
    }]
}];

...我的代码是:

function processTreeNodes(tree, tags) {
    console.log(tags);
    var t = tags || [];
    for (var i=0; i < tree.length; i++) {
        processNode(tree[i], t);
    }
}


function processNode(n, tags) {
    if(n.children) {
        tags.push(n.title);
        //It's a group, loop over it
        processTreeNodes(n.children, tags);
    } else { 
        //Do something with the bookmark
    }
}

chrome.bookmarks.get(function(bmTree) {
    processTreeNodes(bmTree);
});

我期望的是console.log展示

[ 'category1', 'subcat1', ...]

接着

['category2, 'subcatA', ...]

我最终得到的是

['category1, 'subcat1', ..., 'category2', 'subcatA', ...]

它通过并拉出所有信息,但在我看来,当我退回堆栈时,该“级别”的参数尚未保存。我认为这可能与递归/闭包有关,但我迷路了!

抱歉,如果这没有任何意义,我正在努力理解它,让我知道,如有必要,我可以尝试进一步解释!

4

1 回答 1

2

看起来您只创建了一个数组,然后将其传递给所有递归子函数。我将让您编写代码,但看起来您需要在层次结构中的每个点克隆您的数组,以便您传递对新对象的引用,而不是一直传递同一个对象。

于 2012-09-27T14:49:50.550 回答