Как установить пользовательские параметры конструктора в Angular Service при создании его в Angular Component? - PullRequest
0 голосов
/ 17 сентября 2018

Я изменяю класс Typescript на сервис Angular 6:

export class TestClass {
    customParam1;
    customParam2;

    constructor(customParam1, custom1Param2) {
        this.customParam1 = customParam1;
        this.customParam2 = customParam2;
    }
} 

На сервис:

@Injectable({
  providedIn: 'root'
})
export class TestClassService {
    customParam1;
    customParam2;

    constructor(customParam1, custom1Param2) {
        this.customParam1 = customParam1;
        this.customParam2 = customParam2;
    }
} 

При создании первого блока кода в Angular вы вызываете новыйTestClass ("один", "два").

В компоненте как настроить customParam1 и customParam2 при создании службы?

1 Ответ

0 голосов
/ 17 сентября 2018

В случае, если вы не знали,

constructor(customParam1, custom1Param2) {
    this.customParam1 = customParam1;
    this.customParam2 = customParam2;
}

Длинная версия

constructor(private customParam1, private custom1Param2) {}

Теперь по вашему вопросу: поскольку вы предоставляете свои услуги на корневом уровне, он будетсоздать одиночный код: поскольку службы являются зависимостями других функций (например, компонентов), они будут загружены первыми (или их экземпляр будет перенаправлен, но конечная цель та же).

Если вы хотите установить значения в вашем сервисе, вам придется использовать сеттеры: либо функции, либо фактические сеттеры.

setCustomParam1(value) { this.customParam1 = value; }
set setCustomParam2(value) { this.customParam2 = value; }

this.setCustomParam1('your value');
this.setCustomParam2 = 'your value';

В противном случае вам нужно будет создать новый экземпляр вашего сервиса, но это побьет цель одиночных игр.

Лучше всего рассказать нам, чего вы пытаетесь достичь, чтобы мы могли найти для вас наилучшее решение.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...