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

在angular中使用ngIf,但我得到的绑定不能包含赋值

在Angular中使用ngIf指令时,ngIf的绑定表达式不能包含赋值操作。ngIf指令用于根据条件动态地添加或移除DOM元素。它接受一个布尔类型的表达式作为参数,如果表达式的值为true,则显示绑定的元素,否则隐藏。

ngIf的绑定表达式应该是一个返回布尔值的逻辑判断,例如:

代码语言:txt
复制
<div *ngIf="condition">显示内容</div>

在这个例子中,如果condition的值为true,则显示div元素,否则隐藏。

然而,ngIf的绑定表达式不能包含赋值操作,因为赋值操作是一个语句而不是一个表达式。例如,以下代码是不正确的:

代码语言:txt
复制
<div *ngIf="value = 10">显示内容</div>

在这个例子中,value = 10是一个赋值语句,而不是一个返回布尔值的表达式。如果尝试使用这样的绑定表达式,Angular会抛出一个错误。

如果需要在ngIf中进行赋值操作,可以考虑将赋值操作放在组件的逻辑中,然后在ngIf中使用相应的变量进行判断。例如:

代码语言:txt
复制
<div *ngIf="isValueTen">显示内容</div>
代码语言:txt
复制
export class MyComponent {
  isValueTen: boolean;

  constructor() {
    this.isValueTen = this.getValue() === 10;
  }

  getValue(): number {
    return 10;
  }
}

在这个例子中,通过在组件中进行赋值操作,并将结果存储在isValueTen变量中,然后在ngIf中使用isValueTen进行条件判断。

对于Angular中ngIf的更多信息,请参考腾讯云的Angular文档:ngIf

相关搜索:Angular:我不能使用*ngIf在UI中显示Asyn验证器的错误在Angular中的ngIf条件中使用拆分函数在带有ngIf的Angular 5组件上使用事件绑定为什么[hidden]可以,但Angular2中的ngOnInit()不能使用*ngIf?Angular 10在反应式表单中使用ngif进行表单验证的双向数据绑定如何使用ngIf在Angular 7中的三个页面之间切换?在Angular 8中使用ngIf更改图像时的语法编写问题使用RenderScript内部BLAS在Android中执行矩阵运算,但我得到了错误的结果?如何根据用户的操作使用*ngIf angular 2在文本区或<p>中渲染数据?为什么我的离子按钮在使用绑定了离子复选框的布尔值属性的ngIf时不能以正确的状态启动?无法使用jspdf在angular中打印包含pdf转换中输入字段的Html表格如何使用*ngIf条件在angular中显示默认空值按钮*ngFor循环中的like,dislike和default按钮使用Mysql Node.jsAngular中的e2e测试:在firefox中不能使用protractor上传和下载文件尝试在python中对数组的进行线性回归,但我一直收到错误消息“array一定不能包含infs或NaNs”。没有infs或NaNs如何使用Angular 7中的模块在ngFor循环中有条件地绑定类或属性值?我试图使用散列代码在java中运行程序,但我一直得到的结果是散列代码中表达式的非法开始?在使用$q时,angular promise中的catch和finally函数不能工作,但是标准的Promise可以工作--我遗漏了什么?我在angular 6中使用了ag-grid。我已经实现了自定义的全选功能。但在筛选器中进行更改时,全选不能正常工作我有多个包含阿拉伯语值的.sql文件,当我在.bat文件中使用sqlcmd运行它们时,数据库中不能识别阿拉伯语值
相关搜索:
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Angular 显示英雄列表

在 src/app/ 文件夹中创建一个名叫 mock-heroes.ts 的文件。 定义一个包含十个英雄的常量数组 HEROES,并导出它。 该文件是这样的。...Angular 会把所点击的  上的 hero 对象传给它,这个 hero 也就是前面在 *ngFor 表达式中定义的那个。...英雄们显示在列表中,并且所点英雄的详情也显示在了页面的下方。 修复 - 使用 *ngIf 来隐藏空白的细节 该组件应该只有当 selectedHero 存在时才显示所选英雄的详情。...为什么这样是正常的 当 selectedHero 为 undefined 时,ngIf 从 DOM 中移除了英雄详情。因此也就不用担心 selectedHero 的绑定了。...用户可以选择一个英雄,并查看该英雄的详情。 你使用 *ngFor 显示了一个列表。 你使用 *ngIf 来根据条件包含或排除了一段 HTML。 你可以用 class 绑定来切换 CSS 的样式类。

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

    将数据值和一些对于用户的行为约束(某个字段必须填啊、某个字段长度超过了长度限制啊)绑定到组件的模板中,从而完成与用户的交互 4.2.1、模板驱动表单的双向数据绑定 在根模块中引入 FormsModule...在使用 ngModel 进行模板绑定时,angular 在 form 标签上自动附加了一个 NgForm 指令,因为 NgForm 指令会控制表单中带有 ngModel 指令和 name 属性的元素,而...name 属性则是 angular 用来注册控件的 key,所以在表单中使用 ngModel 进行双向数据绑定时,必须要添加 name 属性 4.2.2、跟踪表单控件的状态 在表单中使用 ngModel...类的实例对应于一个表单控件,在使用时,通过将控件的实例赋值给属性,后续则可以通过监听这个自定义的属性来跟踪表单控件的值和状态 import { Component, OnInit } from '@angular...在模板驱动表单中,因为不是直接使用的 FormControl 实例,因此这里应该在模板上添加一个自定义的指令来完成对于控件数据的校验 使用 angular cli 创建一个用来进行表单验证的指令 ng

    18.9K20

    Angular 显示英雄列表

    在 src/app/ 文件夹中创建一个名叫 mock-heroes.ts 的文件。 定义一个包含十个英雄的常量数组 HEROES,并导出它。 该文件是这样的。...Angular 会把所点击的  上的 hero 对象传给它,这个 hero 也就是前面在 *ngFor 表达式中定义的那个。...英雄们显示在列表中,并且所点英雄的详情也显示在了页面的下方。 修复 - 使用 *ngIf 来隐藏空白的细节 该组件应该只有当 selectedHero 存在时才显示所选英雄的详情。...为什么这样是正常的 当 selectedHero 为 undefined 时,ngIf 从 DOM 中移除了英雄详情。因此也就不用担心 selectedHero 的绑定了。...用户可以选择一个英雄,并查看该英雄的详情。 你使用 *ngFor 显示了一个列表。 你使用 *ngIf 来根据条件包含或排除了一段 HTML。 你可以用 class 绑定来切换 CSS 的样式类。

    4K30

    angular知识点梳理第二篇-基本语法

    angular的基本语法,这样有利于后面我们进行梳理别的知识点做一些铺垫 基本语法 常见指令 NgModel NgModel就和vue中的v-model的效果是一致的,只是写法会有一些区别,vue中是可以直接进行使用的...,但是在angular中我们引入框架的一个核心模块FormsModule才可以,该指令就是将数据驱动视图的改变!...在app.modules.ts中引入forms模块 // 核心模块 import { NgModule } from '@angular/core'; //引入forms模块实现数据的双向绑定 import...在需要使用数据绑定的组件进行数据的处理 import { Component, OnInit } from '@angular/core'; @Component({ selector: 'app-home...:hidden是要区别开的,当if判断为false的时候,页面上是整个元素都消失了,而不是仅仅隐藏了css样式 在需要使用数据绑定的组件进行数据的处理 import { Component, OnInit

    2.6K30

    Angular 6.x 快速入门

    第二节 - 插值表达式 在 Angular 中,我们可以使用插值语法实现数据绑定。...基础知识 定义组件的元信息 在 Angular 中,我们可以使用 Component 装饰器来定义组件的元信息: @Component({ selector: 'my-app', // 用于定义组件在...name = 'Angular'; } 定义数据接口 在 TypeScript 中的接口是一个非常灵活的概念,除了可用于对类的一部分行为进行抽象外,也可用于对「对象的形状(Shape)」进行描述...ngIf 指令语法 ngIf="condition">... ngFor 指令简介 该指令用于基于可迭代对象中的每一项创建相应的模板。...2.x', 'Angular 4.x', 'Angular 6.x']; } } 第五节 - 事件绑定 在 Angular 中,我们可以通过 (eventName) 的语法,实现事件绑定。

    14.1K20

    Angular 2 架构(下)

    通过这种机制,可以从HTML里面取值和赋值,使得数据的读写,数据的持久化操作变得更加简单快捷。 如图所示,数据绑定的语法有四种形式。...保存 双向绑: 使用Angular里的NgModel指令可以更便捷的进行双向绑定。...在Angular中包含以下三种类型的指令: 属性指令:以元素的属性形式来使用的指令。 结构指令:用来改变DOM树的结构 组件:作为指令的一个重要子类,组件本质上可以看作是一个带有模板的指令。...*ngIf 表示只有在选择的项存在时,才会包含 SiteDetail 组件。...---- 服务(Services) Angular2中的服务是封装了某一特定功能,并且可以通过注入的方式供他人使用的独立模块。 服务分为很多种,包括:值、函数,以及应用所需的特性。

    2.2K20

    Angular快速学习笔记(3) -- 组件与模板

    显示数据 在 Angular 中最典型的数据显示方式,就是把 HTML 模板中的控件绑定到 Angular 组件的属性。...angular提供两种地方存放组件模板 你可以使用 template 属性把它定义为内联的, 或者把模板定义在一个独立的 HTML 文件中, 再通过 @Component 装饰器中的 templateUrl...它是语法中不可或缺的一部分 通过 NgIf 进行条件显示 有时,应用需要只在特定情况下显示视图或视图的一部分,这个时候使用ngif,同vue.js里的v-if ngIf="heroes.length...Angular 执行这个表达式,并把它赋值给绑定目标的属性,这个绑定目标可能是 HTML 元素、组件或指令。 典型的表达式上下文就是这个组件实例,它是各种绑定值的来源。...典型的语句上下文就是当前组件的实例。 (click)="deleteHero()" 中的 deleteHero 就是这个数据绑定组件上的一个方法。 模板语句不能引用全局命名空间的任何东西。

    15.3K30

    AngularDart4.0 指南- 显示数据 顶

    您可以通过将HTML模板中的控件绑定到Angular组件的属性来显示数据。 在这个页面中,您将创建一个包含英雄列表的组件。 您将显示英雄名单的列表,并有条件地在列表下方显示一条消息。...在模板中使用任何Angular指令之前,您需要将它们列在组件的@Component注解的指令参数中。...在实际应用中,大多数绑定是针对更专业化的对象。 要将此绑定转换为使用专用对象,请将英雄名称列表转换为Hero对象列表。 为此,你需要一个Hero类。... 不要忘记* ngIf中的星号(*)。 这是语法的重要组成部分。 在“模板语法”页面的ngIf部分阅读有关ngIf和*的更多信息。...它正在添加和删除DOM中的段落元素。 这可以提高性能,特别是在大型项目中,当有条件地包含或排除大量的HTML与许多数据绑定。 试试看。 由于列表中有四个项目,所以应该显示消息。

    5.3K10

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

    在 Angular 中,有两种类型的指令。属性指令修改 DOM 元素的外观或者行为。结构指令添加或者移除 DOM 元素。 结构指令是 Angular 中最强大的特性之一,然而它们却频繁被误解。...在 Angular 中,有三种标准的结构化指令。...*ngIf - 根据表达式返回的布尔值,有条件地包含一个模版(即条件渲染模版) *ngFor - 遍历数组 *ngSwitch - 渲染每个匹配的是图 下面是一个结构化指令的例子。...这会将其转换为方括号 [] 中的属性绑定,比如 [ngIf]。 的其余部分,包含类名,插入到 里。...要使用结构指令,我们需要在 HTML 模版中添加一个带有指令的元素。然后根据我们在指令中设置的条件或者表达式添加、删除或者替换元素。 结构指令的例子 我们添加些简单的 HTML 代码。

    3.8K20

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

    ; // 声明一个public的变量并且赋值 }复制代码 app.module.ts:模块 // 浏览器的NG模块 import { BrowserModule } from...,ng2的开发模式就是类似一个树,从根节点无限发散 import { NgModule } from '@angular/core'; // 表单模块,比如你要在组件内用到一些表单元素或者数据绑定..., |是管道,支持多个管道,支持内置管道和自定义管道,:跟随是管道的参数,后续文档我写一个如何自定义管道的文章 []="":绑定组件内的值[单向,数据流向视图],指令,原生html控件的自身属性[value...绑定赋值的条件表达式的特殊之处: 不支持: 赋值 (=, +=, -=, ...) new运算符 使用;或,的链式表达式 自增或自减操作符 (++和--) 不支持位运算|和& 支持: 逻辑运算(...index 动态渲染(*ngIf) *ngIf="item" : 比如loading到视图全部渲染就经常用到这个,当前不在乎低版本的可以用[hidden]来控制切换,因为*ngIf这种动态渲染节点的还是有一定的性能消耗的

    6.2K20

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

    如果名称未能匹配已知指令的元素事件或输出属性,则Angular会报告“未知指令”错误。 $event和事件处理语句 在事件绑定中,Angular为目标事件设置了一个事件处理程序。...幸运的是,Angular NgModel指令是一个使元素形成双向绑定的桥梁。 内置指令 早期版本的Angular包含了七十多个内置指令。 社区贡献了更多,并且为内部应用程序创建了无数私人指令。...在Angular中你不需要这些指令。 通常,您可以使用功能更强大,表现力更强的Angular绑定系统获得相同的结果。 当你可以写一个简单的绑定时为什么要创建一个指令来处理点击呢?...Angular把这条指令翻译成一个围绕宿主元素的,然后重复使用这个模板为列表中的每个英雄创建一组新的元素和绑定。 在“结构指令”指南中了解微语法。...接下来的部分将介绍这些操作符中的两个:管道和安全导航操作符。 管道操作符(|) 在准备使用绑定之前,表达式的结果可能需要进行一些转换。

    30K20

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

    ; // 声明一个public的变量并且赋值 } ``` app.module.ts:模块 // 浏览器的NG模块 import { BrowserModule } from...,ng2的开发模式就是类似一个树,从根节点无限发散 import { NgModule } from '@angular/core'; // 表单模块,比如你要在组件内用到一些表单元素或者数据绑定...[(target)]: 双向数据绑定,视图和数据源同步改动,一般用于表单比较多。 绑定赋值的条件表达式的特殊之处: 不支持: 赋值 (=, +=, -=, ...)...new运算符 使用;或.的链式表达式 自增或自减操作符 (++和--) 不支持位运算|和& 支持: 逻辑运算(|| , &&) 三目运算符( true ?...index 动态渲染(*ngIf) *ngIf="item" : 比如loading到视图全部渲染就经常用到这个,当前不在乎低版本的可以用[hidden]来控制切换,因为*ngIf这种动态渲染节点的还是有一定的性能消耗的

    10810

    Angular2 之 结构型指令几个概念

    它仍然附加子啊它所属于的DOM元素上,它仍然在监听事件。angular会继续检查哪些能影响数据绑定的变更。组件原本要做的哪些事情仍然在进行!它还是占用着那么多的资源。...总结 基于上面的利弊分析,无论是我们在使用内置的指令还是使用自定的指令的时候,我们应该自己分析提添加、移除元素以及创建和销毁组件的后果。...标签 结构型指令,比如ngIf,使用HTML 5的template标签 完成它们的“魔法”。 控制Template标签内DOM添加与显示,在模板级别使用的。...在Angular应用之外,标签的默认CSS属性display是none 。 它的内容存在于一个隐藏的文档片段中。...要么显示的包含在Template标签中,要么隐式的使用*这种语法糖去包装在Template标签中。它简化了ngIf和ngFor —— 无论是写还是读。

    3K20

    浅谈Angular

    Angular里的数据绑定: 1.插值表达式 {{}}--括号里可填表达式,不能填语句!...,即Model向View 如果要实现双向绑定,需要使用到ngModel指令 语法: [(ngModel)]='值' ***直接写指令,在angularJS里会报错,需要人为的引入FormsModule...ng-show本质上设置元素的display值为none,只是设置样式,DOM结构还在,而*ngIf是真正意义上的从DOM结构中移除结构型指令 *ngIf--控制元素的显隐性 ?...可以给@Input装饰器内部填写一个元数据,这个值是外部使用的名字 内部还是使用原来的名字 3.如果想要给指令添加的元素绑定的事件,需要使用@HostListener装饰器 如果要通过指令控制DOM的显隐...,要声明在子组件里 2.子向父 -- @Output装饰器声明事件,要声明在子组件里 3.兄弟之间 -- 中间人模式 拓展:事件源对象 在事件中,当前操作的那个元素就是事件源。

    4.4K10

    Angular DOM 抽象概述

    这在大多数情况下,是没有问题的,但如果我们开发的应用要支持跨平台的话,就不能绑定宿主环境为浏览器。...作用 在应用层直接操作 DOM,就会造成应用层与渲染层之间强耦合,导致我们的应用无法运行在不同环境,如 Web Worker 中,因为在 Web Worker 环境中,是不能操作 DOM。...模板元素是一种机制,允许包含加载页面时不渲染,但又可以随后通过 JavaScript 进行实例化的客户端内容。我们可以将模板视作为存储在页面上稍后使用的一小段内容。...,Angular 为我们开发者提供了 元素,在 Angular 内部它主要应用在结构指令中,比如 *ngIf、*ngFor 等。...在浏览器环境中,虽然通过 ElementRef 的 nativeElement 属性,我们可以方便地获取对应的 DOM 元素,但我们最好不要利用 DOM API 进行 DOM 操作,最好通过 Angular

    3.5K30

    Angular 从入坑到挖坑 - 组件食用指南

    四、Step by Step 4.1、组件与模板 4.1.1、组件的基础概念 组件包含了一组特定的功能,每个组件的功能都单一且独立,可以进行重复使用;组件可以通过 angular cli 进行创建,生成的组件位于工作空间的...4.1.2、模板绑定语法 在 angular 应用中,组件扮演着控制器或是视图模型的作用,在创建组件时会关联一个 html 文件,这个 html 文件则是一个基础的 angular 模板文件 在这个模板文件中...@Input 用来获取数据,@Output 用来向外发送数据 4.4.2、子组件获取父组件信息 在父组件中,添加对于子组件的引用,并将需要传递的数据 or 方法绑定到子组件上 传递数据直接将父组件中的属性值赋值给绑定在子组件上的属性就可以了...传递方法时,绑定在子组件上的属性是父组件方法的名称,此处不能加 () ,否则就会直接执行该父组件的方法 在传递数据给子组件时,也可以通过 this 来指代父组件,从而将整个父组件作为数据绑定子组件上...在组件中使用服务 在需要使用的组件中引入服务,然后在组件的构造函数中通过依赖注入的方式注入这个服务,就可以在组件中完成对于这个服务的使用 在父组件中对数据进行赋值,然后调用服务的方法改变数据信息

    15.8K30

    AngularDart4.0 指南-体系结构概述 顶

    您可以通过使用Angular的标记组合HTML 模板,编写组件类来管理这些模板,在服务中添加应用程序逻辑以及在模块中装入组件和服务来编写Angular应用程序。 然后,通过引导根模块启动应用程序。...当用户点击英雄的名字时,(click)事件绑定调用组件的selectHero方法。 双向数据绑定是一个重要的第四种形式,它使用ngModel指令将属性和事件绑定在一个符号中。..."> 在双向绑定中,与属性绑定一样,数据属性值将从组件输入到输入框中。...它们倾向于以属性的形式出现在元素标签内,有时候以名称的形式出现,但更常见的是作为赋值或绑定的目标。 结构指令通过添加,删除和替换DOM中的元素来改变布局。...= null"> * ngFor告诉Angular在英雄列表中标出每个英雄的一个。 * ngIf仅在选择的英雄存在时才包含HeroDetail组件。

    7.9K30

    AngularDart 4.0 高级-结构指令 顶

    三种常见的内置结构指令 - NgIf,NgFor和NgSwitch ... - 在模板语法指南中进行了描述,并在整个Angular文档中的示例中进行了介绍。...它一直在倾听事件。 Angular不断检查可能会影响数据绑定的更改。 无论组件在做什么,它都会继续这样做。 虽然看不见,但组件及其所有后代组件都会占用资源。...您可以在分配给ngFor的字符串中启用这些功能,这是您在Angular的microsyntax中编写的。...当你编写自己的结构指令时,可以使用这些微观语法机制。 研究NgIf和NgFor的源代码是了解更多信息的好方法。 模板输入变量 模板输入变量是一个变量,其值可以在模板的单个实例中引用。...满足Angular模板中的类似需求。 编写一个结构指令 在本节中,您将编写一个与NgIf相反的UnlessDirective结构指令。 NgIf在条件为true时显示模板内容。

    16.1K20
    领券