Angular, как отобразить результат почтового запроса в компоненте

== выполняет контрольную проверку равенства, ссылаясь на то, что 2 объекта (строки в этом случае) относятся к одному и тому же объекту в памяти.

Метод equals() будет проверять, будет ли содержимое или состояния двух объектов одинаковы.

Очевидно, что == работает быстрее, но во многих случаях может (может) давать ложные результаты, если вы просто хотите сказать, имеет ли 2 String s тот же текст.

Определенно рекомендуется использовать метод equals().

Не беспокойтесь о производительности. Некоторые способы поощрения использования String.equals():

  1. Реализация String.equals() сначала проверяет ссылочное равенство (используя ==), и если две строки одинаковы по ссылке, дальнейший расчет Выполняется!
  2. Если 2 ссылки на строки не совпадают, String.equals() будет проверять длину строк. Это также является быстрой операцией, поскольку класс String хранит длину строки, не нужно считать символы или кодовые точки. Если длины отличаются, дальнейшая проверка не выполняется, мы знаем, что они не могут быть равными.
  3. Только если мы доберемся до этого, будет фактически сопоставлено содержимое двух строк, и это будет короткий сравнение: не все символы будут сравниваться, если мы найдем несоответствующий символ (в том же положении в 2 строках), никакие другие символы не будут проверены.

Когда все сказано и даже если у нас есть гарантия, что строки являются стажерами, использование метода equals() все еще не является издержками, которые можно было бы подумать, определенно рекомендуемым способом. Если вам нужна эффективная проверка ссылок, используйте перечисления, где гарантируется спецификацией и реализацией языка, что одно и то же значение перечисления будет одним и тем же объектом (по ссылке).

1
задан Sole 9 March 2019 в 23:55
поделиться

1 ответ

Для Angular 7.2.0 и выше :

Вы можете сделать это с помощью NavigationExtras , встроенного в Angular Router. Для этого вам нужно добавить только две вещи.

Первый шаг:

Обновление this.route.navigate(['/inc/confirmation']) до этого

this.router.navigate(['/inc/confirmation'],{state: {response}});

Второй шаг: [1117 ]

Во втором компоненте вы можете получить доступ к state, добавив его в свой код

const state = this.router.getCurrentNavigation().extras.state;
this.response = state.response;

Затем вы можете отобразить его.

Для угловых 7 и ниже:

Первый шаг:

Обновление this.route.navigate(['/inc/confirmation']) до этого

[119 ]

Второй шаг:

Во втором компоненте вы можете получить доступ к state, добавив его в свой код

constructor(private route: ActivatedRoute){}
 ...
this.value = this.route.snapshot.queryParamMap.get('value');

Затем вы можете покажите его.

Если вы не хотите использовать параметр URL:

Вы можете создать службу с одним свойством

@Injectable({
  providedIn: 'root'
})
export class SharedDataService {
  public sharedData;
  constructor() {
  }
}

Затем вы можете установить sharedData перед вами. перенаправить на другой маршрут.

constructor(private sharedService: SharedDataService){}
...
this.sharedService.sharedData = response;
this.route.navigate(['/inc/confirmation']);

Вы можете получить эти данные во втором компоненте.

constructor(private sharedService: SharedDataService){}
...
this.response = this.sharedService.sharedData;
0
ответ дан Josef Katič 9 March 2019 в 23:55
поделиться
Другие вопросы по тегам:

Похожие вопросы: