首页 > 解决方案 > Manifest V3 服务工作者中的异步代码是否在与其启动位置相同的执行上下文中解析/完成?

问题描述

我的 MV3 扩展中有如下代码:

import _ from 'lodash'; 

const storageKey = 'state';
let state;
(async () => {
  state = await chrome.storage.local.get(storageKey);
  listener();
})();

const update = async (data) => {
  await chrome.storage.local.set({[storageKey]: data});
}

let lastPick;
const listener = async () => {
  const pick = _.pick(state, ...);
  if (_.isEqual(pick, lastPick))
    return;
  lastPick = pick;
  ...
  // do some stuff
}

chrome.storage.onChanged.addListener((changes, area) => {
  if (area !== 'local' || !(storageKey in changes))
    return;
  const {newValue} = changes[storageKey];
  state = newValue;
  listener();
});

chrome.tabs.onActivated.addListener(async (data) => {
  ...
  update(...);
  ...
  update(...);
  ...
  update(...);
});

使用经典的 Manifest V2 扩展,我可以确定 of 的值lastPick将始终通过listener调用(这又由多个调用引起)保持不变,因此不会破坏其中的update“某些东西”逻辑。listener

但是 Manifest V3,或者更准确地说,它的服务工作者呢?我可以确信上述逻辑不会在那里被打破吗?

标签: javascriptgoogle-chrome-extensionchrome-extension-manifest-v3

解决方案



推荐阅读