How to pass parameters rendered from backend to angular2 bootstrap method

前端 未结 4 561
感动是毒
感动是毒 2020-11-21 23:58

Is there a way to pass arguments rendered on the backend to angular2 bootstrap method? I want to set http header for all requests using BaseRequestOptions with value provide

4条回答
  •  醉话见心
    2020-11-22 00:40

    In Angular2 final release, the APP_INITIALIZER provider can be used to achieve what you want.

    I wrote a Gist with a complete example: https://gist.github.com/fernandohu/122e88c3bcd210bbe41c608c36306db9

    The gist example is reading from JSON files but can be easily changed to read from a REST endpoint.

    What you need, is basically:

    a) Set up APP_INITIALIZER in your existent module file:

    import { APP_INITIALIZER } from '@angular/core';
    import { BackendRequestClass } from './backend.request';
    import { HttpModule } from '@angular/http';
    
    ...
    
    @NgModule({
        imports: [
            ...
            HttpModule
        ],
        ...
        providers: [
            ...
            ...
            BackendRequestClass,
            { provide: APP_INITIALIZER, useFactory: (config: BackendRequestClass) => () => config.load(), deps: [BackendRequestClass], multi: true }
        ],
        ...
    });
    

    These lines will call the load() method from BackendRequestClass class before your application is started.

    Make sure you set "HttpModule" in "imports" section if you want to make http calls to the backend using angular2 built in library.

    b) Create a class and name the file "backend.request.ts":

    import { Inject, Injectable } from '@angular/core';
    import { Http } from '@angular/http';
    import { Observable } from 'rxjs/Rx';
    
    @Injectable()
    export class BackendRequestClass {
    
        private result: Object = null;
    
        constructor(private http: Http) {
    
        }
    
        public getResult() {
            return this.result;
        }
    
        public load() {
            return new Promise((resolve, reject) => {
                this.http.get('http://address/of/your/backend/endpoint').map( res => res.json() ).catch((error: any):any => {
                    reject(false);
                    return Observable.throw(error.json().error || 'Server error');
                }).subscribe( (callResult) => {
                    this.result = callResult;
                    resolve(true);
                });
    
            });
        }
    }
    

    c) To read the contents of the backend call, you just need to inject the BackendRequestClass into any class of you choice and call getResult(). Example:

    import { BackendRequestClass } from './backend.request';
    
    export class AnyClass {
        constructor(private backendRequest: BackendRequestClass) {
            // note that BackendRequestClass is injected into a private property of AnyClass
        }
    
        anyMethod() {
            this.backendRequest.getResult(); // This should return the data you want
        }
    }
    

    Let me know if this solves your problem.

提交回复
热议问题