Angular中的?.和!.到底有什么区别?
创始人
2024-10-31 02:00:20
0

在 Angular 中,?. 和 !. 都是安全导航操作符,用于处理可能为 null 或未定义的属性或方法。

?. 操作符是安全的管道,用于防止在引用 null 或未定义值的情况下抛出异常。它在尝试访问属性或调用方法时检查对象是否为 null 或 undefined,如果是,则返回 undefined,而不是抛出异常。

! 操作符是非空断言操作符,表示运算符右边的表达式不会为 null 或 undefined,否则会抛出异常。

下面是一个示例,展示了如何使用这两个操作符:

interface Foo {
  bar?: {
    baz: string;
  };
}

const foo: Foo = { bar: { baz: 'hello' } };

// 使用 ?. 操作符
const result1 = foo.bar?.baz;  // 'hello'

// 使用 ! 操作符
const result2 = foo.bar!.baz;  // 'hello'

在上面的示例中,使用 ?. 操作符和 ! 操作符从对象 foo 中获取属性值 baz。当 foo.bar 为 null 或 undefined 时,?. 操作符返回 undefined,! 操作符会抛出异常。由于 foo.bar 是有定义的,所以两个操作符都返回 'hello'。

相关内容

热门资讯

黑科技辅助挂!(AAPOKEr... 黑科技辅助挂!(AAPOKEr)一贯是真的有挂,(aa扑克)果然真的有挂,攻略教程(有挂透明)1、上...
黑科技辅助挂!(WpK)其实有... 黑科技辅助挂!(WpK)其实有挂,(WPK)一贯真的有挂,技巧教程(有挂神器);黑科技辅助挂!(Wp...
黑科技辅助挂!(AAPOKeR... 黑科技辅助挂!(AAPOKeR)果然真的是有挂,(Aapoker)确实是真的有挂,AI教程(有挂黑科...
黑科技辅助挂!AAPOKer透... 黑科技辅助挂!AAPOKer透明挂德州辅助工具,(aaPOKER)切实有挂,详细教程(有挂科技)1、...
黑科技辅助!WepOke透明挂... 黑科技辅助!WepOke透明挂透视挂靠谱,(wePOke)总是有挂,详细教程(有挂总结)1、任何we...
黑科技辅助!wePOKE透明挂... 黑科技辅助!wePOKE透明挂软件规律,(wEPoke)果然是真的有挂,透视教程(有挂软件);wEP...
黑科技辅助挂!(WEpoke)... 黑科技辅助挂!(WEpoke)总是真的有挂,(wEPoke)都是真的是有挂,科技教程(有挂辅助器);...
黑科技辅助挂!wpK透视辅助,... 黑科技辅助挂!wpK透视辅助,(wpK)原来真的是有挂,细节方法(有挂神器)1、很好的工具软件,可以...
黑科技辅助!WePoke透明挂... 黑科技辅助!WePoke透明挂模拟器,(WePoke)确实是有挂,黑科技教程(有挂插件)WePoke...
黑科技辅助挂!wEpoke软件... 黑科技辅助挂!wEpoke软件透明挂,wePokE透明挂可以识别,总结教程(有挂透明挂)运wePok...