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

Angular2/4 ngFor指令不允许变量赋值

Angular2/4中的ngFor指令用于在模板中循环渲染一组元素。它允许我们遍历一个数组或对象,并为每个元素生成相应的HTML代码。

在ngFor指令中,变量赋值是不允许的。ngFor指令的语法如下:

代码语言:txt
复制
<element *ngFor="let item of items; let i = index">
  <!-- 循环渲染的内容 -->
</element>

在上述代码中,items是一个数组或对象,item是当前循环的元素,i是当前元素的索引。

如果想要在ngFor指令中对变量进行赋值操作,可以通过调用组件中的方法来实现。例如,可以在组件中定义一个方法,接收当前循环的元素作为参数,并在该方法中对变量进行赋值操作。

以下是一个示例:

代码语言:txt
复制
<element *ngFor="let item of items; let i = index">
  {{ assignValue(item) }}
</element>
代码语言:txt
复制
export class MyComponent {
  items: any[] = [/* 数组或对象 */];
  assignedValue: any;

  assignValue(item: any) {
    // 对变量进行赋值操作
    this.assignedValue = item.property;
    return this.assignedValue;
  }
}

在上述示例中,assignValue方法接收当前循环的元素作为参数,并将其某个属性的值赋给assignedValue变量。然后,在模板中通过插值表达式{{ assignedValue }}来显示赋值后的结果。

需要注意的是,ngFor指令的主要目的是循环渲染元素,而不是进行变量赋值操作。因此,在使用ngFor指令时,应尽量避免对变量进行赋值操作,以保持代码的简洁和可读性。

推荐的腾讯云相关产品:腾讯云云服务器(CVM),腾讯云云数据库MySQL版(CDB),腾讯云对象存储(COS)。

  • 腾讯云云服务器(CVM):提供可扩展的计算容量,用于部署和运行应用程序。详情请参考:腾讯云云服务器
  • 腾讯云云数据库MySQL版(CDB):提供高性能、可扩展的关系型数据库服务,用于存储和管理数据。详情请参考:腾讯云云数据库MySQL版
  • 腾讯云对象存储(COS):提供安全、可靠的对象存储服务,用于存储和管理大规模的非结构化数据。详情请参考:腾讯云对象存储
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

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

---- 基础概念 国内的官网--基础 词汇表(又名计算机术语--angular2 & es6 & es7) 速查表:又名demo写法表,里面涵盖了很多写法,相当于一本小字典 关于ng2的一堆为什么:...; // 声明一个public的变量并且赋值 }复制代码 app.module.ts:模块 // 浏览器的NG模块 import { BrowserModule } from...绑定赋值的条件表达式的特殊之处: 不支持: 赋值 (=, +=, -=, ...) new运算符 使用;或,的链式表达式 自增或自减操作符 (++和--) 不支持位运算|和& 支持: 逻辑运算(...true : false ) 直接赋值运算(item = 2); 变量传递 空值保护运算符(?.) item?.a?....,用来动态判断增加多个样式 [class.a]或者[style.font-size]:单一操作类或者某个行内样式 数据遍历(*ngFor) *ngFor="let i of item; let index

6.2K20

Angular 2 架构(下)

通过这种机制,可以从HTML里面取值和赋值,使得数据的读写,数据的持久化操作变得更加简单快捷。 如图所示,数据绑定的语法有四种形式。...当 Angular 渲染它们时,它会根据指令对 DOM 进行修改。 指令是一个带有"指令元数据"的类。在 TypeScript 中,要通过 @Directive 装饰器把元数据附加到类上。...在Angular中包含以下三种类型的指令: 属性指令:以元素的属性形式来使用的指令。 结构指令:用来改变DOM树的结构 组件:作为指令的一个重要子类,组件本质上可以看作是一个带有模板的指令。... *ngFor 告诉 Angular...---- 服务(Services) Angular2中的服务是封装了某一特定功能,并且可以通过注入的方式供他人使用的独立模块。 服务分为很多种,包括:值、函数,以及应用所需的特性。

2.2K20
  • Angular2 VS Angular4 深度对比:特性、性能

    Google的Angular团队已于3月23日发布了Angular4,而期待已久的Angular2版本则是之前版本的完全重构。...那么,本文将会对Angular2和Angular4进行深度对比,以便帮助大家更好的了解这两个版本。 Angular2 Angular2是在2015年底发布的。...动态载入: 这是之前的Angular版本均不具备的功能,Angular2包含了这个功能,即使在开发人员忙碌时,也能够添加新的指令或控件。 模板: 在Angular2中,模板编译过程是异步的。...指令Angular2提供了三种指令:  组件指令:通过将逻辑封装在HTML,CSS和JavaScript中,从而使得组件可复用。...改进 *ngIf 和 *ngFor: 模板绑定语法目前支持一些少量有帮助的更改。现在,开发人员已经可以使用if/else设计​​语法,并分配局部变量了。

    8.7K20

    Angular核心概念:数据绑定

    (达内教育学习笔记)仅供学习交流 Angular数据绑定 Angular核心概念:数据绑定(1)HTML绑定:{{NG表达式}}(2)属性绑定(3)指令绑定(4)事件绑定()(5)双向数据绑定指令...:[(ngModel)]---重点 Angular核心概念:数据绑定 (1)HTML绑定:{{NG表达式}} (2)属性绑定 (3)指令绑定 (4)事件绑定() (5)双向数据绑定指令:[(ngModel...)}} (2)属性绑定 形式1:直接在属性上用{{}}现在有的版本禁用 直接在属性上使用 形式2:直接使用[]推荐 注意:属性绑定通常赋值变量...循环绑定:ngFor <any *ngFor=“let...: 1.组件指令:NG中Component继承自Directive 2.结构型指令:会影响DOM树结构,必须使用开头,如ngFor,*ngIf 3.属性型指令:不会影响DOM树结构,只是影响元素外观或行为

    3.5K10

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

    而路由、网络模块、指令、管道、服务等属于angular的技术范畴。 Ionic1基于Angular1开发。...由于AngularJS 1.x版本在性能上已经很难有较大提升,后来微软和google联合推出了全新设计的基于TypeScript的Angular2,这是对于原始版本完全的重写。...等到angular2的更新到了一定版本,一些依赖库分属于2和3,为了便于版本的统一管理,直接跳到了angular4,其实angualr2和4两者的变化不算太多。相应的ionic2也同步升级到3。...,其它变化不大,具体更新如下: Angular 4.0 新的版本下,改进 AOT 编译器,分离 animations 包,缩小生成后的代码量,运行更快,改进ngIf 和ngFor 等具体内容可以访问...angular4更新来查看。

    2.7K40

    AngularDart 4.0 高级-结构指令

    NgFor和NgSwitch ...指令遵循相同的模式。 *ngFor内部详解 Angular以类似的方式将*ngFor转换为从星号(*)语法通过模板属性到模板元素。...NgFor指令具有比本指南中显示的NgIf更多的功能,包括必需的和可选的。 至少NgFor需要一个循环变量(let hero)和一个列表(heroes)。...当你编写自己的结构指令时,可以使用这些微观语法机制。 研究NgIf和NgFor的源代码是了解更多信息的好方法。 模板输入变量 模板输入变量是一个变量,其值可以在模板的单个实例中引用。...变量的作用域限于重复模板的单个实例。 您可以在其他结构指令的定义中再次使用相同的变量名称。 您通过在#(#var)前缀加上变量名称来声明一个模板引用变量。 引用变量是指其附加的元素,组件或指令。...你在指令构造函数中注入这两个类作为类的私有变量

    16.1K20

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

    内置指令 内置的属性指令       NgClass       NgStyle       NgModel ([(ngModel)]) 内置结构指令      NgIf      NgFor          ...模板输入变量           Microsyntax     NgSwitch指令 模板引用变量(#var) 输入和输出属性(@Input和@Output) 模板表达式运算符     管道(|)    ...最后,它将这个复合插值结果赋值给一个元素或指令属性 您似乎在元素标记之间插入结果并将其分配给属性。这么想很方便,你会因为这个错误而受苦。虽然这不完全正确。...如果引用这些名称空间的名称,则模板变量名称优先,后面是指令的上下文,最后是组件的成员名称。 前面的例子显示了这样一个名字冲突。 该组件具有hero属性,而* ngFor定义了英雄模板变量。...模板语句解析器与模板表达式解析器不同,特别支持基本的赋值(=)和链接表达式(with;) 但是,某些Dart语法是不允许的: new 和 const 递增和递减运算符,++和 -- 赋值运算符,例如 +

    5.2K10

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

    通过添加核心指令* ngFor修改标签。 ngFor的前缀(*)是此语法的关键部分。...ngFor指令遍历组件的英雄列表并为该列表中的每个英雄呈现该模板的一个实例。 表达式部分将hero标识为模板输入变量,其中包含每个迭代的英雄详情。...在显示数据的Showing a list property with *ngFor部分阅读更多关于ngFor和模板输入变量和模板语法页的ngFor部分 在节点内添加内容hero模板变量来显示英雄属性...onSelect(hero)表达式调用AppComponent方法onSelect(),传递模板输入变量hero作为参数。 这是你在ngFor指令中定义的同一个英雄变量。...在结构指令页面和模板语法页面的内置指令部分阅读有关ngIf和ngFor的更多信息。 格式化选中hero 当选择的英雄细节显示在列表下方时,很难在列表中识别选定的英雄。

    3K30

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

    分配给* ngFor的文本是指导迭代器进程的指令。 *ngFor微语法 分配给* ngFor的字符串不是模板表达式。 这是一种微语法 - Angular解释的一种小语言。...模板输入变量 hero之前的let关键字创建一个名为hero的模板输入变量ngFor指令迭代由父组件的heroes属性返回的heroes,并在每次迭代期间将hero设置为列表中的当前项目。...* ngFor与index(索引) NgFor指令上下文的index属性返回每个迭代中项目的从零开始的索引。 您可以捕获模板输入变量中的index,并在模板中使用它。... 模板引用变量(#var) 模板引用变量通常是对模板内DOM元素的引用。 它也可以是对Angular组件或指令或Web组件的引用。 使用hash符号(#)来声明一个引用变量。...模板引用变量警告说明 模板引用变量(#phone)与模板输入变量(let phone)不同,如您在*ngFor中可能看到的那样。 了解“结构指令”指南中的差异。 引用变量的范围是整个模板。

    30K20

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

    5={{1+2+3+4+5}} ?...模板表达式的变量来源 模板本身的变量 指令的上下文变量 组件的成员信息(属性 or 方法) 在使用模板表达式时,如果变量名在多个来源中都存在的话,则模板变量是最优先的,其次是指令的上下文变量,最后是组件的成员...(refMsgInput.value)"> 通过模板引入变量的方式获取到输入的值:{{refMsg}} 4.2、指令 4.2.1、属性型指令 属性型指令被应用在视图 dom 元素上,用来改变...指令上下文中的 index 属性在每次迭代中,会获取到条数据的索引值 当渲染的数据发生改变时 4,会导致 dom 元素的重新渲染,此时可以采用 trackBy 的方式,通过在组件中添加一个方法,指定循环需要跟踪的属性值...非空断言运算符 在 tsconfig.json 中启用 strictNullChecks 属性,typescript 将会强制开启严格的空值检查,在这种模式下,所有定义了类型的属性是不允许赋值为 null

    15.8K30
    领券