-2

下面的代码属于我目前正在尝试开发的跨浏览器扩展,希望能够跨浏览器同步书签。该文件当前是 background.js 文件,它将首先从本地数据库中检索书签文件的快照,然后将其与当前的书签列表进行比较,如果有任何差异(添加到书签列表或减去),它们将使用 getChanges() 函数返回,然后发送到服务器,最后脚本更新快照并等待 30 秒,然后重新启动进程。我真的不知道如何制作 getChanges() 函数。它可能需要返回一个 json 对象,指示加法和减法(它们的标题和 url)。如果有人可以为该功能编写代码,那就太好了。谢谢

appAPI.ready(function() {
// Poll every 30 seconds
setInterval(function() {
  appAPI.db.async.get('prevBookmarks', function(value) {
  // Load or initialize previous bookmarks list
  var prevBookmarks = (value) ? value : {};

  // Get current bookmarks
  appAPI.bookmarks.getTree(function(nodes) {
    // Save bookmark list for next comparison
    appAPI.db.async.set('prevBookmarks', nodes);

    // In your getChanges functions, traverse the bookmark trees collating
    // changes and then post then to your API server using appAPI.request
    var changes = getChanges(prevBookmarks, nodes);
    appAPI.request.post({
      url: http://yourAPIserver.com,
      postData: changes,
      contentType: 'application/json'
    });
  });
});
}, 30 * 1000);
});
4

1 回答 1

0

好的,您已将 jQuery 作为您的标签之一,因此请尝试以下链接:比较返回差异的 2 个数组

它返回两个数组之间的差异。你必须为你正在做的事情执行两次,一次是为了弄清楚里面有什么current不在里面,previous反之亦然。我不知道您的书签中包含哪些属性,因此这个简单的示例可能不完全适合您的需求,但它可能会为您指明正确的方向。

祝你好运,欢迎使用 JavaScript!

于 2013-07-03T02:41:50.387 回答