如何使用API​​将Chrome书签与扩展中的服务器同步

时间:2015-09-25 17:34:32

标签: javascript jquery google-chrome google-chrome-extension bookmarks

我正在创建一个Chrome扩展程序,可让您查看,更新,创建和删除Chrome书签。我还希望能够通过我们的服务器加载并保存用户的书签,而不是通过谷歌帐户进行同步。我遇到的问题是,我不确定如何跨设备同步这些书签。由于Chrome bookmarks API没有任何方法来加载/同步树,我想我会将每个书签/文件夹保存在服务器上的数组中,例如

[{id: "", parentId: "", index: "", title: "", url: ""}, ...]

当用户在新设备/浏览器上登录他们的帐户时,我从服务器获取书签/文件夹数组并循环浏览它们。在循环中,我会使用带有ID的Chrome.bookmarks.get来检查该书签是否已存在,如果不存在,则使用create函数创建该书签。问题是,我无法在文档中看到指定新创建的书签/文件夹的ID。如果在新设备/浏览器上创建的书签/文件夹具有与原始设备/浏览器不同的ID,该怎么办?然后使用get函数(需要您指定要查找的ID)将不允许我正确地比较书签。这个问题还有另一个解决方案吗?

1 个答案:

答案 0 :(得分:0)

我实际上最终使用Chrome书签搜索功能按网址和标题搜索书签,然后进行匹配以查看父ID是否匹配。这种做法很简单,但它确实有效!

function initBookmarks(){
  //hit endpoint to get array of current bookmarks
  var curBookmarks = [
    {
      id : "7",
      parentId : "1",
      index : 12,
      title : "A programmatically generated bookmark",
      url : "http://google.com"
    },
    {
      id : "8",
      parentId : "1",
      index : 13,
      title : "A programmatically generated bookmark 2",
      url : "http://google.com"
    }
  ];

  if(curBookmarks.length > 0){
    curBookmarks.forEach(function(bookmark,index){
      console.log("searching.. ", {url : bookmark.url, title : bookmark.title});
      chrome.bookmarks.search({url : bookmark.url, title : bookmark.title}, function(result){
        console.log('result for search for is', result, bookmark.title);
        var flagExists = false;
        for(var i = 0; i < result.length; i++){
          if(result[i].parentId === bookmark.parentId) flagExists = true;
        }

        if(!flagExists){
          chrome.bookmarks.create({
            parentId: bookmark.parentId,
            index: bookmark.index,
            title: bookmark.title,
            url: bookmark.url
          }, function(){
            console.log('IVE CREATED!!!');
            if(index === curBookmarks.length-1)
              chrome.bookmarks.getTree(parseBookmarks);
          });
        }
        else{
          if(index === curBookmarks.length-1)
            chrome.bookmarks.getTree(parseBookmarks);
        }
      })
    })
  }
  else{
    chrome.bookmarks.getTree(parseBookmarks);
  }

}