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'。

相关内容

热门资讯

线上(wepoke真的)原来是... 线上(wepoke真的)原来是真的有挂!其实真的有挂(2022已更新)(哔哩哔哩);亲,其实确实真的...
两教程(Wepoke程序)软件... 两教程(Wepoke程序)软件透明挂辅助工具(软件透明挂)透视辅助(2024已更新)(哔哩哔哩);致...
软件(wepoke透明)原来是... 软件(wepoke透明)原来是真的有挂!其实真的有挂(2020已更新)(哔哩哔哩)是一款可以让一直输...
一模拟器(德扑工具)外挂辅助工... 一模拟器(德扑工具)外挂辅助工具(透视)透视辅助(2025已更新)(哔哩哔哩);亲真的是有正版授权,...
系统(aapoker讲解)竟然... 系统(aapoker讲解)竟然真的有挂!其实真的有挂(2021已更新)(哔哩哔哩);aapoker讲...
6系统(aapoker下载)外... 6系统(aapoker下载)外挂辅助工具(辅助挂)透视辅助(2023已更新)(哔哩哔哩)aapoke...
智能(德扑之星刷数据)果真真的... 智能(德扑之星刷数据)果真真的有挂!原来真的有挂(2025已更新)(哔哩哔哩);《WPK辅助透视》‌...
1机器人(德州nzt软件)软件... 1机器人(德州nzt软件)软件透明挂辅助软件(透视)透视辅助(2022已更新)(哔哩哔哩);人气非常...
ai代打(德扑之星决策)确实是... ai代打(德扑之星决策)确实是真的有挂!原来真的有挂(2020已更新)(哔哩哔哩);科技详细教程小薇...
第8透明(wepoke数据)外... 第8透明(wepoke数据)外挂透明挂辅助神器(辅助挂)透视辅助(2023已更新)(哔哩哔哩);原来...