首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

无法在*ngIf angular2指令中设置条件

ngIf angular2指令中,我们无法直接设置条件。ngIf是Angular中的一个结构指令,用于根据条件来添加或移除DOM元素。它的语法是*ngIf="condition",其中condition是一个布尔表达式。

*ngIf指令的作用是根据condition的值来决定是否渲染DOM元素。如果condition为true,则元素会被渲染;如果condition为false,则元素会被移除。

ngIf指令中,我们只能使用布尔表达式作为条件,而不能直接在指令中设置条件。如果需要在ngIf指令中设置复杂的条件,可以在组件中定义一个布尔类型的变量,并在模板中使用该变量作为条件。

例如,假设我们在组件中定义了一个名为showElement的布尔类型变量,我们可以在模板中使用它来控制元素的显示与隐藏:

代码语言:txt
复制
<div *ngIf="showElement">
  这是一个根据条件显示的元素
</div>

在组件中,我们可以通过改变showElement的值来控制元素的显示与隐藏:

代码语言:txt
复制
export class MyComponent {
  showElement: boolean = true;

  toggleElement() {
    this.showElement = !this.showElement;
  }
}

上述代码中,showElement的初始值为true,所以元素会被显示。当调用toggleElement方法时,showElement的值会被取反,从而控制元素的显示与隐藏。

对于Angular中的条件判断,我们可以使用一些其他的指令来实现更复杂的条件逻辑,如ngIf-else、ngSwitch等。这些指令可以根据不同的条件来渲染不同的DOM元素。

总结起来,*ngIf指令用于根据条件来添加或移除DOM元素,但我们无法直接在指令中设置条件,而是需要在组件中定义一个布尔类型的变量,并在模板中使用该变量作为条件。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

ionic3应该善用组件和指令

angular4提供了很多功能强大的内置指令,但在现实情况,这些内置指令可能还不能完全满足实际要求,这时我们就需要编写自定义指令来实现特定要求。...angular1时代,组件和指令是一回事,即严格来说,没有组件这概念,只有指令,而到了angular2时代,虽说组件仍是一种特殊的指令,但已经有一定目的明显区分开来,分别用Directive和Component...其实就是模版指令,如ngIf,当条件为true时,该元素会被添加到DOM。其主要依赖TemplateRef和ViewContainerRef来完成操作。...与其他指令不同,它描述的是一个视图,是用户可以直接看到的东西。 自定义属性指令 实例:创建一个bgColor属性指令,支持传入颜色名参数,设置目标标签的背景色 1)创建指令。...自定义结构指令 实例:山寨一个*ngIf的的收缩显示指令,仅为了起到抛砖引玉效果。

3.5K40

Angular2 @NgModule

一个模块内部可以包含组件、指令、管道,并且可以将它们的访问权限声明为公有,以使外部模块的组件可以访问和使用到它们。...模块是用来组织应用的,通过模块机制外部类库可以很方便的扩展应用,Angular2将许多常用功能都分配到一个个的模块,如:FormModule、HttpModule、RouterModule。...(Angular2没有模块级别的service,所有NgModule声明的Provider都是注册根级别的Dependency Injector) ---- 3.imports:导入其他...module,其它module暴露的出的Components、Directives、Pipes等可以本module的组 件中被使用 。...比如导入CommonModule后就可以使用NgIf、NgFor等指令。 ---- 4.exports:用来控制将哪些内部成员暴露给外部使用。

2.1K40
  • Angular 2 架构(下)

    插值 : HTML 标签显示组件值。 {{title}} 属性绑定: 把元素的属性设置为组件属性的值。...当 Angular 渲染它们时,它会根据指令对 DOM 进行修改。 指令是一个带有"指令元数据"的类。 TypeScript ,要通过 @Directive 装饰器把元数据附加到类上。...Angular包含以下三种类型的指令: 属性指令:以元素的属性形式来使用的指令。 结构指令:用来改变DOM树的结构 组件:作为指令的一个重要子类,组件本质上可以看作是一个带有模板的指令。...*ngIf 表示只有选择的项存在时,才会包含 SiteDetail 组件。...---- 服务(Services) Angular2的服务是封装了某一特定功能,并且可以通过注入的方式供他人使用的独立模块。 服务分为很多种,包括:值、函数,以及应用所需的特性。

    2.2K20

    Angular 2 + 折腾记 :(2)初步认识angular2,不一样的开发模式

    ---- 基础概念 国内的官网--基础 词汇表(又名计算机术语--angular2 & es6 & es7) 速查表:又名demo写法表,里面涵盖了很多写法,相当于一本小字典 关于ng2的一堆为什么:...,src,class,style]等,双引号内支持条件表达式[不完全等同于js条件表达式]或者方法亦或者变量, (click)="": 事件绑定[视图触发改变数据源],同上,支持表达式和方法。。...绑定赋值的条件表达式的特殊之处: 不支持: 赋值 (=, +=, -=, ...) new运算符 使用;或,的链式表达式 自增或自减操作符 (++和--) 不支持位运算|和& 支持: 逻辑运算(...of item; let index = index": 可以用这个来遍历数组对象,let index = index意思是创建一个局部遍历把当前遍历的索引保存到你的自定义变量index 动态渲染(*ngIf...) *ngIf="item" : 比如loading到视图全部渲染就经常用到这个,当前不在乎低版本的可以用[hidden]来控制切换,因为*ngIf这种动态渲染节点的还是有一定的性能消耗的。。

    6.2K20

    Angular 结构指令模式 - 它们是什么且怎么使用

    Angular ,有两种类型的指令。属性指令修改 DOM 元素的外观或者行为。结构指令添加或者移除 DOM 元素。 结构指令是 Angular 中最强大的特性之一,然而它们却频繁被误解。...结构指令在其名字之前都有 * 符号。 Angular ,有三种标准的结构化指令。...要使用结构指令,我们需要在 HTML 模版添加一个带有指令的元素。然后根据我们指令设置条件或者表达式添加、删除或者替换元素。 结构指令的例子 我们添加些简单的 HTML 代码。...指令 我们根据条件来使用 *ngIf 来确定展示或者移除一个元素。...typescript : Myshopping: string = ''; 我们有一个 MyShopping 变量,它有一个默认值,用于模块渲染满足条件的特定元素。

    3.8K20

    AngularDart 4.0 高级-结构指令

    与其他指令一样,您将结构指令应用于宿主元素。 然后该指令会执行它应该对该宿主元素及其后代所做的任何操作。 结构指令很容易识别。 在此示例,星号(*)指令属性名称前面。...每个结构指令都与该模板有所不同。 三种常见的内置结构指令 - NgIf,NgFor和NgSwitch ... - 模板语法指南中进行了描述,并在整个Angular文档的示例中进行了介绍。...您可以在其他结构指令的定义再次使用相同的变量名称。 您通过#(#var)前缀加上变量名称来声明一个模板引用变量。 引用变量是指其附加的元素,组件或指令。 它可以整个模板的任何地方访问。...满足Angular模板的类似需求。 编写一个结构指令 本节,您将编写一个与NgIf相反的UnlessDirective结构指令NgIf条件为true时显示模板内容。... 当条件为假时,出现顶部(A)段落并且底部(B)段落消失。 条件为真时,顶部(A)段被删除,底部(B)段出现。 ? 概要 您可以尝试实例查看本指南的源代码(查看源代码)。

    16.1K20

    【开发指南】(三)认识ionic3

    而路由、网络模块、指令、管道、服务等属于angular的技术范畴。 Ionic1基于Angular1开发。...由于AngularJS 1.x版本性能上已经很难有较大提升,后来微软和google联合推出了全新设计的基于TypeScript的Angular2,这是对于原始版本完全的重写。...,其它变化不大,具体更新如下: Angular 4.0 新的版本下,改进 AOT 编译器,分离 animations 包,缩小生成后的代码量,运行更快,改进ngIf 和ngFor 等具体内容可以访问...@IonicPage装饰器 ionic2导航器不是基于url的,如果想使用url访问就要通过DeepLinker来实现,这是比较麻烦的,而在新版本可以通过@IonicPage装饰器来实现。...并且可以更轻松的项目中设置延迟加载,设置延迟加载页面的优先级,并为每个页面自定义配置。

    2.7K40

    理解Angular*ngIf指令中加问号和不加问号的区别

    Angular开发,我们经常使用ngIf指令来根据条件动态渲染或移除元素。然而,一些情况下,我们可能需要处理一些可能为空的对象属性。这时,就需要了解ngIf指令中使用加问号和不加问号的区别。...是一个条件操作符,用于保证访问对象属性时避免空指针异常。...具体来说,加上问号的条件操作符能够保证当pickModel或depotSaleAreaName为null或undefined时,*ngIf="pickModel?....指令条件,所以元素被渲染出来。...总结一下,加问号和不加问号Angular中使用*ngIf指令的区别主要在于处理对象属性是否为空时的表现。我们可以根据具体的业务需求来选择合适的方式,确保代码的可靠性和稳定性。

    31000

    Angular2 之 结构型指令几个概念

    移除元素组件 利 把ngIf设置为false,将会影响到组件的资源消耗。angular会从DOM移除该元素,停止相关组件的变更检测,把它从DOM事件移除,并且销毁组件。...总结 基于上面的利弊分析,无论是我们使用内置的指令还是使用自定的指令的时候,我们应该自己分析提添加、移除元素以及创建和销毁组件的后果。...标签 结构型指令,比如ngIf,使用HTML 5的template标签 完成它们的“魔法”。 控制Template标签内DOM添加与显示,模板级别使用的。...Angular应用之外,标签的默认CSS属性display是none 。 它的内容存在于一个隐藏的文档片段。...自定义指令 我们自顶一个类似ngIf指令

    3K20

    【Angular教程】-内容投影u002F@ContentChildu002F@ViewChild

    ---- 前言 这一篇我们带来的是关于组件基础使用的最后一块,内容投影和Vue的插槽很类似,组件封装的时候非常有用,我们一起来体验一下。 正文 1....使用 ng-template 元素,你可以让组件根据你想要的任何条件显式渲染内容,并可以进行多次渲染。显式渲染 ng-template 元素之前,Angular 不会初始化该元素的内容。...使用ng-container定义我们的投影区块 使用ngTemplateOutlet指令来渲染ng-template元素。 通过内置的动态指令*ngIf来控制是否渲染投影。...this.app.expanded; } constructor(public app: PageContainerComponent) {} } 我们的容器组件申明刚才定义的内容指令,页面目前不报错咯...: ContentDirective; } 通过日志可以看到我们切换容器组件的expanded标识时,只有开启状态my-hello组件才会初始化,下面的这个ngIf虽然页面看不到渲染的内容,但组件实实在在被初始化过了

    54830

    浅谈Angular

    语法: [(ngModel)]='值' ***直接写指令,angularJS里会报错,需要人为的引入FormsModule模块 3.指令: 结构型指令 1....ng-show本质上设置元素的display值为none,只是设置样式,DOM结构还在,而*ngIf是真正意义上的从DOM结构移除结构型指令 *ngIf--控制元素的显隐性 ?...ng-show本质上设置元素的display值为none,只是设置样式,DOM结构还在,而*ngIf是真正意义上的从DOM结构移除 *ngFor--动态创建DOM结构 ngSwitch--通过匹配case...来控制元素的显隐 自定义指令里获取指令添加到其上面的元素,需要依赖注入ElementRef服务 如果自定义指令想要接收从外部传入的值,需要使用@Input装饰器\....,要声明子组件里 2.子向父 -- @Output装饰器声明事件,要声明子组件里 3.兄弟之间 -- 中间人模式 拓展:事件源对象 事件,当前操作的那个元素就是事件源。

    4.4K10

    AngularDart4.0 指南- 模板语法二 顶

    150 : 50" >Small 虽然这是设置单个样式的好方法,但是同时设置多个内联样式时,通常首选NgStyle指令。...如果名称未能匹配已知指令的元素事件或输出属性,则Angular会报告“未知指令”错误。 $event和事件处理语句 事件绑定,Angular为目标事件设置了一个事件处理程序。...为什么你只能应用一个结构指令到一个元素。 本节介绍常见的结构指令NgIf:有条件地从DOM添加或删除元素。 NgFor:为列表的每个项目重复一个模板。...NgSwitch:只显示多个可能元素的一个。 NgIf  您可以通过向该元素应用NgIf指令(称为宿主元素)来添加或移除DOM的元素。 在此示例,将指令绑定到条件表达式,如isActive。...NgSwitch指令 NgSwitch就像Dart switch语句。 它可以根据切换条件从几个可能的元素显示一个元素。 Angular只把选中的元素放入DOM

    30K20

    AngularDart4.0 英雄之旅-教程-04明细 顶

    必备条件 继续本“英雄之旅”页面之前,请确认您在“英雄编辑器”页面之后具有以下结构。 如果您的结构不匹配,请返回该页面以弄清楚您错过了什么。 ? 如果该应用尚未运行,请启动该应用。...然后添加ngIf核心指令并将其设置为selectedHero!= null。lib/app_component.html (ngIf) <div *ngIf="selectedHero !...刷新浏览器,该应用程序不再失败,名称列表再次显示浏览器。 当没有选定的英雄时,ngIf指令从DOM移除英雄详情HTML。 没有英雄细节元素或绑定担心。...结构指令页面和模板语法页面的内置指令部分阅读有关ngIf和ngFor的更多信息。 格式化选中hero 当选择的英雄细节显示列表下方时,很难列表识别选定的英雄。...您了解了如何在组件模板中使用核心指令ngIf和ngFor。 您在CSS文件定义了样式,并使用它们来设置应用程序的样式。 你的应用应该看起来像这个实例(查看源代码)。

    3K30

    Angular 从入坑到挖坑 - 表单控件概览

    使用 ngModel 进行模板绑定时,angular form 标签上自动附加了一个 NgForm 指令,因为 NgForm 指令会控制表单带有 ngModel 指令和 name 属性的元素,而...4.2.3、数据的有效性验证 某些时候需要对于用户输入的信息做有效性验证,此时可以控件上添加上原生的 HTML 表单验证器来设定验证条件,当表单控件的数据发生变化时,angular 会通过指令的方式对数据进行验证...4.4、表单的自定义数据验证 4.4.1、自定义验证器 很多的情况下,原生的验证规则无法满足我们的需要,此时需要创建自定义的验证器来实现 对于响应式表单,我们可以定义一个方法,对控件的数据进行校验,之后将方法作为参数添加到控件定义处即可...模板驱动表单,因为不是直接使用的 FormControl 实例,因此这里应该在模板上添加一个自定义的指令来完成对于控件数据的校验 使用 angular cli 创建一个用来进行表单验证的指令 ng...g directive direactives/hero-validate 创建完成指令之后,我们需要将这个指令将该验证器添加到已经存在的验证器集合,同时为了使这个指令可以与 angular 表单集成在一起

    18.9K20

    过渡到 Angular 17 的新控制流语法

    传统指令与Angular 17的控制流语法对比让我们使用一些示例来比较传统指令和Angular 17的控制流语法:*ngIf指令 vs @if控制块Before(传统 *ngIf):*ngIf指令和async管道 vs @if和asyncBefore(带有 *ngIf 的 async 管道):.../src/component-to-be-migrated转义 {、} 和 @ 字符:模板,现有的 {、} 和 @ 字符作为文本字符使用时需要进行转义。...例如,某些情况下,您可以使用 @defer 块来延迟加载内容。向后兼容性和性能Angular 17允许您在应用程序同时使用新旧语法。...结论Angular 17引入的新控制流语法处理Angular应用程序的模板和渲染逻辑方面带来了显著的改进。转换到这种新语法,承诺会使我们的代码更易读、易维护和高性能。

    67120
    领券