Есть ли у расширений Chrome доступ к локальному хранилищу? - PullRequest
27 голосов
/ 28 января 2010

Можно ли хранить данные таким образом, чтобы они были доступны после перезапуска браузера в контексте расширения Chrome?

Ответы [ 6 ]

44 голосов
/ 10 февраля 2010

Еще проще:

Читать:

    var myStoredValue = localStorage["TheKeyToMyStoredValue"];

Написать:

    localStorage["TheKeyToMyStoredValue"] = myNewValueToStore;

Чтобы избавиться от:

    delete localStorage["TheKeyToMyStoredValue"];
21 голосов
/ 28 января 2010

Да, это так. Полное описание того, как это сделать, вероятно, превысит длину разумного ответа StackOverflow, поэтому я отсылаю вас к этому очень обширному учебнику от Rajdeep Dua. *

Соответствующий код будет выглядеть так:

// Store item in local storage:
function setItem(key, value) {
  try {
    log("Storing [" + key + ":" + value + "]");
    window.localStorage.removeItem(key);      // <-- Local storage!
    window.localStorage.setItem(key, value);  // <-- Local storage!
  } catch(e) {
    log("Error inside setItem");
    log(e);
  }
  log("Return from setItem" + key + ":" +  value);
}

// Gets item from local storage with specified key.
function getItem(key) {
  var value;
  log('Retrieving key [' + key + ']');
  try {
    value = window.localStorage.getItem(key);  // <-- Local storage!
  }catch(e) {
    log("Error inside getItem() for key:" + key);
  log(e);
  value = "null";
  }
  log("Returning value: " + value);
  return value;
}

// Clears all key/value pairs in local storage.
function clearStrg() {
  log('about to clear local storage');
  window.localStorage.clear(); // <-- Local storage!
  log('cleared');
}

function log(txt) {
  if(logging) {
    console.log(txt);
  }
}
7 голосов
/ 29 марта 2010

Chrome также поддерживает спецификацию HTML5 Web Database . Это дает вам локальную базу данных SQL, поэтому вы можете делать более сложные вещи, чем просто хранить пары имя / значение в Local Storage.

5 голосов
/ 28 января 2010

Текущая версия Chrome имеет локальное хранилище.

Я использовал это сам. Вы можете использовать modernizr, чтобы определить, поддерживает ли его браузер или нет. Я написал решение для клиента, в котором я использую откат к cookie, если локального хранилища не существует, но это не должно быть проблемой для расширений.

3 голосов
/ 14 января 2015

В настоящее время может быть лучше использовать chrome.storage chrome.storage является асинхронным, что делает его быстрее, а localStorage ограничен 5 МБ.

1 голос
/ 29 февраля 2016

здесь уже есть несколько хороших ответов, но учтите, что если вы решите использовать скрипт содержимого в своем расширении, этот скрипт контента не будет иметь доступа к localStorage. поэтому chrome.storage является хорошей альтернативой.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...