Angular: @ рдХреЛрдгреАрдп/рднрд╛рд╖рд╛-рд╕реЗрд╡рд╛: рд╕рдЦреНрдд рдирд▓рдЪреЗрдХ рдФрд░ рдПрдирдЬреАрдЖрдИрдПрдл рдХреЗ рд▓рд┐рдП рд╕рдорд░реНрдерди

рдХреЛ рдирд┐рд░реНрдорд┐рдд 1 рдлрд╝рд░ре░ 2018  ┬╖  1рдЯрд┐рдкреНрдкрдгреА  ┬╖  рд╕реНрд░реЛрдд: angular/angular

рдореИрдВ рдПрдХ рдЬрдорд╛ рдХрд░ рд░рд╣рд╛ рд╣реВрдБ ...


[ ] Regression (a behavior that used to work and stopped working in a new release)
[ ] Bug report  <!-- Please search GitHub for a similar issue or PR before submitting -->
[X] Feature request
[ ] Documentation issue or request
[ ] Support request => Please do not submit support request here, instead see https://github.com/angular/angular/blob/master/CONTRIBUTING.md#question

рд╡рд░реНрддрдорд╛рди рд╡реНрдпрд╡рд╣рд╛рд░

рдЬрдм рдЯрд╛рдЗрдкрд╕реНрдХреНрд░рд┐рдкреНрдЯ рдХрдВрдкрд╛рдЗрд▓рд░ рд╡рд┐рдХрд▓реНрдк strictNullChecks рд╕рдХреНрд╖рдо рд╣реЛрддрд╛ рд╣реИ, рддреЛ @angular/language-service рддреНрд░реБрдЯрд┐рдпрд╛рдБ рдлреЗрдВрдХрддрд╛ рд╣реИред

рдЙрджрд╛рд╣рд░рдг:

image

interface Foo {
  bar: string;
}

@Component({
  selector: 'app-foo',
  templateUrl: './foo.component.html'
})
export class FooComponent {
  foo?: Foo;
}

рдЙрджрд╛рд╣рд░рдг 1:

<app-foo *ngIf="foo" [bar]="foo.bar"></app-foo>

рдЙрджрд╛рд╣рд░рдг 2:

<div *ngIf="foo">{{ foo.bar }}</div>
Error: ng: The expression might be null

рдЕрдкреЗрдХреНрд╖рд┐рддреН рд╡реНрдпрд╡рд╣рд╛рд░

рдореБрдЭреЗ рдЙрдореНрдореАрдж рд╣реИ рдХрд┐ *ngIf рд╡рд╕реНрддреБ рдХреЛ рд╢реВрдиреНрдп рди рд╣реЛрдиреЗ рдкрд░ рдЬреЛрд░ рджреЗрдЧрд╛, рдЗрд╕рд▓рд┐рдП рдореИрдВ рдЗрд╕реЗ рдмрд┐рдирд╛ рдХрд┐рд╕реА рддреНрд░реБрдЯрд┐ рдХреЗ рд╕реБрд░рдХреНрд╖рд┐рдд рд░реВрдк рд╕реЗ рдЙрдкрдпреЛрдЧ рдХрд░ рд╕рдХрддрд╛ рд╣реВрдВред

рдкрд░реНрдпрд╛рд╡рд░рдг


Angular version: 5.2.2
- Node version: 8.9.1
- Platform:  MacOS
- Typescript 2.6.2
language-service feature

рд╕рдмрд╕реЗ рдЙрдкрдпреЛрдЧреА рдЯрд┐рдкреНрдкрдгреА

рдореИрдВ рдЗрд╕реЗ рдПрдХ рдмрдЧ рдХреЗ рд░реВрдк рдореЗрдВ рдорд╛рдиреВрдВрдЧрд╛, рдлреАрдЪрд░ рдЕрдиреБрд░реЛрдз рдирд╣реАрдВред

рд╕рдЦреНрдд рдирд▓рдЪреЗрдХ рд╕рдХреНрд╖рдо рд╣реЛрдиреЗ рдХреЗ рд╕рд╛рде рднрд╛рд╖рд╛ рд╕реЗрд╡рд╛ рдЕрдиреБрдкрдпреЛрдЧреА рд╣реИред

>рд╕рднреА рдЯрд┐рдкреНрдкрдгрд┐рдпрд╛рдБ

рдореИрдВ рдЗрд╕реЗ рдПрдХ рдмрдЧ рдХреЗ рд░реВрдк рдореЗрдВ рдорд╛рдиреВрдВрдЧрд╛, рдлреАрдЪрд░ рдЕрдиреБрд░реЛрдз рдирд╣реАрдВред

рд╕рдЦреНрдд рдирд▓рдЪреЗрдХ рд╕рдХреНрд╖рдо рд╣реЛрдиреЗ рдХреЗ рд╕рд╛рде рднрд╛рд╖рд╛ рд╕реЗрд╡рд╛ рдЕрдиреБрдкрдпреЛрдЧреА рд╣реИред

рдХреНрдпрд╛ рдпрд╣ рдкреГрд╖реНрда рдЙрдкрдпреЛрдЧреА рдерд╛?
0 / 5 - 0 рд░реЗрдЯрд┐рдВрдЧреНрд╕

рд╕рдВрдмрдВрдзрд┐рдд рдореБрджреНрджреЛрдВ

gugamm picture gugamm  ┬╖  3рдЯрд┐рдкреНрдкрдгрд┐рдпрд╛рдБ

wangzilong picture wangzilong  ┬╖  3рдЯрд┐рдкреНрдкрдгрд┐рдпрд╛рдБ

robwormald picture robwormald  ┬╖  3рдЯрд┐рдкреНрдкрдгрд┐рдпрд╛рдБ

alxhub picture alxhub  ┬╖  3рдЯрд┐рдкреНрдкрдгрд┐рдпрд╛рдБ

wfalkwallace picture wfalkwallace  ┬╖  3рдЯрд┐рдкреНрдкрдгрд┐рдпрд╛рдБ