24

我正在尝试在发出请求后删除onRequest添加的侦听器,如下所示:chrome.extension.onRequest.addListener

chrome.extension.onRequest.addListener(
    function(request){
        chrome.extension.onRequest.removeListener();
        other_function(request);
    }
);

问题是我不知道这是否有效。我试过chrome.extension.onRequest.hasListener了,这似乎没有给出正确的答案,所以我想知道是否有其他方法可以删除onRequest监听器或检查监听器是否存在。

谢谢!

4

3 回答 3

48

removeListener接受一个论点。您需要命名侦听器函数,然后按名称将其删除:

function doStuff(request){
    chrome.extension.onRequest.removeListener(doStuff);
    other_function(request);
}
chrome.extension.onRequest.addListener(doStuff);

或者,更简洁地说:

chrome.extension.onRequest.addListener(
    function doStuff(request){
        chrome.extension.onRequest.removeListener(doStuff);
        other_function(request);
    }
);
于 2012-05-05T23:03:35.283 回答
9

使用匿名函数时的另一种简单直接的方法:

chrome.runtime.onMessage.addListener(function(msg, sender, reply) {
    chrome.runtime.onMessage.removeListener(arguments.callee);
});
于 2016-11-02T07:42:11.983 回答
0
// define listener(s)
const createListener = (id, bookmark) => {
  // do something
};

React.useEffect(() => { 
  // Add listener(s)
  chrome.bookmarks.onCreated.addListener(createListener);

  // Return a function that removes listener(s)
  return () => {
    chrome.bookmarks.onCreated.removeListener(createListener);
  };
}, []);
于 2022-02-01T21:51:14.807 回答