我想在chrome.webRequest
API中注册一个监听器,就像下面的JS示例一样:
var initHttpRequestObserver = function () {
chrome.webRequest.onBeforeSendHeaders.addListener(
function (details) {...},
{urls: ["<all_urls>"]},
["blocking", "requestHeaders"]);
}();
我想我可以使用dart:js
,但想要使用chrome
包并节省一些时间/打字:
Stream<Map> aStream = chrome.webRequest.onBeforeSendHeaders;
很遗憾,我无法找到如何提供强制性filter
和opt_extraInfoSpec
参数。
答案 0 :(得分:2)
在对chrome
包进行一些分析之后,似乎没有预见到使用多个参数(回调)调用addListener
。 common.dart
包含实际调用的私有方法:
void _ensureHandlerAdded() {
if (!_handlerAdded) {
// TODO: Workaround an issue where the event objects are not properly
// proxied in M35 and after.
var jsEvent = _api[_eventName];
JsObject event = (jsEvent is JsObject ? jsEvent : new JsObject.fromBrowserObject(jsEvent));
event.callMethod('addListener', [_listener]);
_handlerAdded = true;
}
}
显然event.callMethod('addListener', [_listener]);
没有提供额外的参数。
&#34;官方&#34; chrome
包需要修复。在此期间,可以使用旧的dart:js
并执行以下操作:
JsObject _OnBeforeSendHeaders = context['chrome']['webRequest']['onBeforeSendHeaders'];
var filter = new JsObject.jsify({"urls": ["<all_urls>"]});
var opt_extraInfoSpec = new JsObject.jsify(["blocking", "requestHeaders"]);
_OnBeforeSendHeaders.callMethod('addListener', [_processCallback, filter, opt_extraInfoSpec]);