(я думаю), я получил его работать:
@Injectable()
class MyDefaultHeaders extends HttpDefaultHeaders {
@override
setHeaders(Map<String, String> headers, String method) {
super.setHeaders(headers, method);
//if(method.toUpperCase() == 'POST') {
headers['X-Requested-With'] = 'XMLHttpRequest';
//}
}
}
@NgComponent(selector: 'my-comp', publishAs: 'ctrl', template:
'<div>My component</div>')
class MyComponent {
Http http;
MyComponent(this.http) {
//http.request('http://www.google.com/');
var h = http;
// debugger didn't show http so I filed https://code.google.com/p/dart/issues/detail?id=17486
Map m = {};
http.defaults.headers.setHeaders(m, 'GET');
print(m);
// prints:
// {Accept: application/json, text/plain, */*, X-Requested-With: XMLHttpRequest}
}
}
class MyAppModule extends Module {
MyAppModule() {
type(MyComponent);
type(HttpDefaultHeaders, implementedBy: MyDefaultHeaders);
init.createParser(this);
}
}
Я не мог изучить http
проверить заголовки, так как отладчик не показывал мне поле, но как указано в комментарии , когда я применяю headers.setHeaders
сделать карту внутри MyComponent
Я получаю свой собственный заголовок (это то, что Http
делает с headers
) я использовал DI 0.0.33
, Angular 0.9.9
Он работает как шарм. –
Вышеприведенный пример не работал в Angular v12, потому что ему нужен '@Injectable()' в MyDefaultHeaders. –
Спасибо за подсказку. Я добавил. –