Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
Chrome Extension

В хроме не работает хранилище на фоновой странице

23.01.2024, 07:42. Показов 3669. Ответов 31
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
3 года уже делаю своё расширение для браузерной игры.
Хром решил, что манифест 2й версии надо запретить.
Ну это ладно, все переделки в манифесте:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
"manifest_version": 2
 
"permissions":
[
    "https://www.ееее.ru/*"
]
 
"background":
{
        "background": "background.js"
}
>>>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
"manifest_version": 3
 
"host_permissions":
[
    "https://www.ееее.ru/*"
]
 
"background":
{
        "service_worker": "background.js"
}
Но теперь у меня ошибка вылетает:
Error in event handler: ReferenceError: localStorage is not defined at chrome-extension://ccjcdehmcgflmglpjhdgfpfhjgjifhme/background.js:421:11
localStorage не определен:
JavaScript
1
resp({respId: req.respId, onof: localStorage['tb_onoff'], sale: localStorage['sale_openpage'], walk: localStorage['walk_map']})
Гуглил, пробовал так:
JavaScript
1
resp({respId: req.respId, onof: localStorage.getItem('tb_onoff'), sale: localStorage.getItem('sale_openpage'), walk: localStorage.getItem('walk_map')})
Всё-равно ошибка.

В манифесте указано хранилище:
JavaScript
1
2
3
4
5
6
7
8
"permissions":
[
    "alarms",
    "storage",
    "tabs",
    "activeTab",
    "webNavigation"
]
Кто знает в чём проблема?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.01.2024, 07:42
Ответы с готовыми решениями:

Вывести на aspx странице список файлов из определенной папки расположенной на сетевом хранилище
Добрый день\ ой ночи) Подскажите возможно ли на сайт aspx ный вывести список файлов из определенной папки расположенной на сетевом...

Каким плагином в гугл хроме можно узнать отказы по странице?
каким плагином в гугл хроме можно узнать отказы по странице?

Не работает хранилище shelve
я создал простенькое хранилище shelve, но когда я его запускаю в интерактивной подсказке у меня показывается что оно пустое. вот код...

31
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
29.01.2024, 12:01  [ТС]
Студворк — интернет-сервис помощи студентам
Нашел:

JavaScript
1
2
3
4
5
6
7
8
9
10
11
const readLocalStorage = async (key) =>
{
  return new Promise((resolve, reject) =>
  {
    chrome.storage.local.get([key], function (result)
    {
      if (result[key] === undefined) reject();
      else resolve(result[key]);
    });
  });
};
JavaScript
1
2
3
4
5
6
7
8
9
async function getData()
{
  let key1 = await readLocalStorage('key1');
  object1.innerHTML = key1;
  let key2 = await readLocalStorage('key1');
  object1.innerHTML = key2;
 
  continueCode();
}
0
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
29.01.2024, 14:59  [ТС]
И всё равно не работает.

Это глобальные:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
const GetLocalStorage = async (key) =>
{
    return new Promise((resolve, reject) =>
    {
        chrome.storage.local.get([key], function (result)
        {
            if(result[key] === undefined) reject()
            else resolve(result[key])
        })
    })
}
async function getData(x)
{
  let key = await GetLocalStorage(x)
  
  return key
}
Это уже непосредственно в коде:
JavaScript
1
console.log(getData('onof'))
Вот опять белиберда:
0
 Аватар для voraa
1241 / 1136 / 178
Регистрация: 21.01.2024
Сообщений: 5,182
29.01.2024, 17:14
Ну тут просто надо возвращать значение undefined

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
const GetLocalStorage = async (key) =>
{
    return new Promise((resolve, reject) =>
    {
        chrome.storage.local.get([key], function (result)
        {
           resolve(result[key])
        })
    })
}
 
async function getData(x)
{
  let key = await GetLocalStorage(x)
  
  return key
}
А что, просто
JavaScript
1
value = await chrome.storage.local.get([key])
не работает?
1
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
29.01.2024, 21:01  [ТС]
Нет. Мне нужно получить настройки расширения, и в зависимости от них, выполнить или нет код.
Т.е. асинхронный метод не подходит.
0
 Аватар для voraa
1241 / 1136 / 178
Регистрация: 21.01.2024
Сообщений: 5,182
29.01.2024, 21:16
Цитата Сообщение от артист Посмотреть сообщение
Т.е. асинхронный метод не подходит.
А чему он мешает?
Ну если с callback, то это такой же асинхронный код, только записывается более криво. С callback очень трудно дожидаться, когда все операции завершатся.
А без асинхронного кода не получится, т.к. сами функции chrome.storage асинхронные.
1
 Аватар для voraa
1241 / 1136 / 178
Регистрация: 21.01.2024
Сообщений: 5,182
30.01.2024, 12:29
Не так
JavaScript
1
2
3
4
5
6
7
8
9
async function getData()
{
  let key1 = await readLocalStorage('key1');
  object1.innerHTML = key1;
  let key2 = await readLocalStorage('key1');
  object1.innerHTML = key2;
 
  continueCode();
}
Вот так надо
JavaScript
1
2
3
4
5
6
7
8
9
async function getData()
{
  let res = await readLocalStorage(['key1']);
  object1.innerHTML = res.key1;
  res = await readLocalStorage(['key2']);
  object1.innerHTML = res.key2;
 
  continueCode();
}
А еще проще

JavaScript
1
2
3
4
5
6
7
8
async function getData()
{
  let res = await readLocalStorage(['key1', 'key2']);
  object1.innerHTML = res.key1;
  object1.innerHTML = res.key2;
 
  continueCode();
}
1
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
01.02.2024, 08:21  [ТС]
Это не мой код. Я нашел его в инете. И он не работает.
Вообще ничего не работает. Нахрен этот гугл.
0
168 / 146 / 32
Регистрация: 03.09.2018
Сообщений: 499
01.02.2024, 10:01
Я бы уже давно на вашем месте загрузил любое расширение подходящего функционала, и посмотрел как там реализовано. Его можно распаковать тем же 7z
0
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
01.02.2024, 12:59  [ТС]
Это где такое найти. С 3м манифестом.
0
168 / 146 / 32
Регистрация: 03.09.2018
Сообщений: 499
01.02.2024, 13:12
Цитата Сообщение от артист Посмотреть сообщение
Это где такое найти. С 3м манифестом.
Ты же написал что 2 заблокировали, значит в сторе можно найти расширение на 3 в лёгкой доступности. Далее посмотреть где оно хранится на жёстком диске, и распаковать его,

Добавлено через 2 минуты
%localappdata%\Google\Chrome\User Data\Default\Extensions

Добавлено через 3 минуты
"FastProxy - обход блокировки сайтов"

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
{
   "action": {
      "default_icon": "icon-enabled.png",
      "default_popup": "popup/popup.html"
   },
   "background": {
      "service_worker": "sw.js"
   },
   "description": "Расширение позволяет беспрепятственно заходить на заблокированные сайты.",
   "homepage_url": "https://fastproxy.online",
   "host_permissions": [ "\u003Call_urls>" ],
   "icons": {
      "128": "icon-128-enabled.png",
      "32": "icon-enabled.png"
   },
   "key": "*****",
   "manifest_version": 3,
   "minimum_chrome_version": "104.0.0.0",
   "name": "FastProxy - обход блокировки сайтов",
   "optional_permissions": [ "management" ],
   "permissions": [ "proxy", "tabs", "webRequest", "storage", "unlimitedStorage", "alarms", "scripting" ],
   "short_name": "FastProxy",
   "update_url": "https://clients2.google.com/service/update2/crx",
   "version": "7.0.4"
}
Видим что оно 3 версии
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
//console.log('Hello from -> Devtool');
 
const init = () => {
  try {
    const version = localStorage.getItem('resources-saver-version');
    if (version === '2') {
      return chrome.devtools.panels.create('ResourcesSaver', 'icon.gif', 'devtool.app.html', function (panel) {
        console.log('Content is loaded to panel', panel);
      });
    }
 
    if (version === '0.1.9') {
      return chrome.devtools.panels.create('ResourcesSaver', 'icon.gif', 'legacy/0.1.9/devtool.app.html', function (panel) {
        console.log('Content is loaded to panel', panel);
      });
    }
 
    return chrome.devtools.panels.create('ResourcesSaver', 'icon.gif', 'legacy/0.1.8/devtool.app.html', function (panel) {
      console.log('Content is loaded to panel', panel);
    });
  } catch {
    return chrome.devtools.panels.create('ResourcesSaver', 'icon.gif', 'legacy/0.1.8/devtool.app.html', function (panel) {
      console.log('Content is loaded to panel', panel);
    });
  }
};
 
init();

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
//console.log('Hello from -> Popup');
const handleSwitchVersion = (version) => {
  document.querySelectorAll('.switch-version-btn').forEach((i) => i.setAttribute('class', 'switch-version-btn'));
  if (version === '0.1.8') {
    localStorage.setItem('resources-saver-version', '0.1.8');
    return document.getElementById('switch-version-1-8').setAttribute('class', 'switch-version-btn active');
  }
  if (version === '0.1.9') {
    localStorage.setItem('resources-saver-version', '0.1.9');
    return document.getElementById('switch-version-1-9').setAttribute('class', 'switch-version-btn active');
  }
  if (version === '2') {
    localStorage.setItem('resources-saver-version', '2');
    return document.getElementById('switch-version-2').setAttribute('class', 'switch-version-btn active');
  }
};
 
window.onload = () => {
  document.getElementById('switch-version-1-8').addEventListener('click', () => {
    handleSwitchVersion('0.1.8');
  });
 
  document.getElementById('switch-version-1-9').addEventListener('click', () => {
    handleSwitchVersion('0.1.9');
  });
 
  document.getElementById('switch-version-2').addEventListener('click', () => {
    handleSwitchVersion('2');
  });
 
  const version = localStorage.getItem('resources-saver-version');
 
  if (version === '2') {
    return document.getElementById('switch-version-2').setAttribute('class', 'switch-version-btn active');
  }
 
  if (version === '0.1.9') {
    return document.getElementById('switch-version-1-9').setAttribute('class', 'switch-version-btn active');
  }
 
  return document.getElementById('switch-version-1-8').setAttribute('class', 'switch-version-btn active');
};
Упс а тут localStorage.setItem Работает же как то ?
1
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
01.02.2024, 20:43  [ТС]
Цитата Сообщение от Именч Посмотреть сообщение
Ты же написал что 2 заблокировали
Там было написано, что старые могут оставаться на 2м, а вот новые - нет.

Цитата Сообщение от Именч Посмотреть сообщение
Работает же как то ?
Не знаю. Может у меня с хромом что-то случилось.
В принципе он не хочет в аккаунт входить, надо попробовать переустановить.

Добавлено через 3 минуты
Надо попробовать выставить:
Цитата Сообщение от Именч Посмотреть сообщение
JavaScript
1
"unlimitedStorage"
И минимальную версию хрома повыше.
0
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
20.02.2024, 08:53  [ТС]
Не работает и всё.
Как бесят все эти тупые обновления, из-за которых больше проблем.
То тема слетит, то цвет папок в закладках становиться таким же как и полоса, то шрифт изменят...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.02.2024, 08:53
Помогаю со студенческими работами здесь

Функция JS работает на одной странице проекта C# asp net core, но выдает ошибку 400 (Bad Request) на другой странице
Здравствуйте! Есть 2 .cshtml страницы. Одна для добавления объекта - Create.cshtml: @model voteCollector.Models.Friend @{ ...

Не отображается "чекбокс" в Хроме и Опере, при большом масштабе странице
Возникли проблемы с "чекбоксом" в Хроме и Опере, если увеличить масштаб страницы то он исчезает, но при проверке элементов страницы, его...

Как работает карантин (или хранилище вирусов) в антивирусе
Возьмем пример: Avast... Как он делает так, чтобы: "Объекты, помещенные в карантин, не представляют угрозу для вашего компьютера так...

Не работает в Хроме
Подскажите пожалуйста что мне сделать, чтобы заработало в хроме? ...

Не работает JS в Хроме
в мазиле все работает как надо в хроме не работает не появляется скрытый див echo '<div id="plan"...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
32
Ответ Создать тему
Опции темы

Новые блоги и статьи
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru