javascript – chrome.storage.local.get在调用时导致“Undefined”

我正在构建一个chrome扩展,我需要在本地保存一些数据;所以我使用了
Storage API.我必须运行简单的示例并保存数据,但是当我将其与我的应用程序集成时,它无法找到数据并且给我“未定义”结果.

这是我的代码:

    function saveResults(newsId, resultsArray) {
//Save the result
        for(var i = 0; i < resultsArray.length; i++) {
            id = newsId.toString() + '-' + i.toString();
            chrome.storage.local.set({ id : resultsArray[i] });
        }
//Read and delete the saved results
        for(var i = 0; i < resultsArray.length; i++) {
            id = newsId.toString() + '-' + i.toString();
            chrome.storage.local.get(id, function(value){
                alert(value.id);
            });
            chrome.storage.local.remove(id);
        }
    }

最佳答案 我不确定您要保存的数据类型或数量,但在我看来,每个可能有多个newsId和一个不同长度的resultsArray.而不是为每个结果元素创建键,而是考虑将整个事物按原样存储.一个例子是:

chrome.storage.local.set({'results':[]});

function saveResults(newsId, resultsArray) {
  // first combine the data into one object
  var result = {'newsId':newsId, 'resultsArray':resultsArray};

  // next we will push each individual results object into an array
  chrome.storage.get('results',function(item){
    item.results.push(result);
    chrome.storage.set({'results':item.results});
  });
}

function getResults(newsId){
  chrome.storage.get('results', function(item){
    item.results.forEach(function(v,i,a){
      if(v.newsId == newsId){
        // here v.resultsArray is the array we stored
        // we can remove any part of it such as
        v.resultsArray.splice(0,1);
        // or
        a.splice(i,1);
        // to remove the whole object, then simply set it again
        chrome.storage.local.set({'results':a});
      }
    });
  });
}

这样您就不必担心动态命名任何字段或键.

点赞