- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想使用 TypeScript
创建一个简单的 Angular2
应用程序。看起来,很简单,但我无法实现我想要的。
我想在模板中显示属性值。我想在 1 秒后使用 setTimeout 更新它。
Plunkr 代码在这里:Code on Plunkr
我写的是这里:
import {Component} from 'angular2/core';
interface Hero {
id: number;
name: string;
}
@Component({
selector: 'my-app',
template:`<h1>Number Increment</h1><p>{{n}}</p>`
})
export class AppComponent {
public n : number = 1;
setTimeout(function() {
n = n + 10;
}, 1000);
}
当我使用此代码时出现以下错误:
Uncaught SyntaxError: Unexpected token ;
为什么我无法访问 n
,它与我们过去在 JavaScript 中的作用域相同。如果我没记错的话,我们也可以在 TypeScript 中使用纯 JavaScript。
我什至尝试过
export class AppComponent {
public n : number = 1;
console.log(n);
}
但我无法在控制台中看到 n
的值。
当我尝试过
export class AppComponent {
public n : number = 1;
console.log(this);
}
我收到与上述相同的错误。为什么我们不能在这个地方访问它。我想,this
指的是 JavaScript 中的当前上下文。
最佳答案
这不是有效的 TypeScript 代码。您不能在类的主体中调用方法。
// INVALID CODE
export class AppComponent {
public n: number = 1;
setTimeout(function() {
n = n + 10;
}, 1000);
}
而是将 setTimeout
调用移至类的 constructor
。此外,使用箭头函数 =>
可以访问 this
。
export class AppComponent {
public n: number = 1;
constructor() {
setTimeout(() => {
this.n = this.n + 10;
}, 1000);
}
}
在 TypeScript 中,您只能通过 this
来引用类的属性或方法。这就是箭头函数 =>
很重要的原因。
关于typescript - Angular2 - typescript : Increment a number after timeout in AppComponent,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34529557/
我已经查看了 Microsoft 的 MSDN 和整个网络,但我仍然无法很好地了解它是什么。 这是否意味着已完成的程序在执行期间的不同时间加载 DLL,而不是在启动时一次性加载所有 DLL? 我完全偏
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Is there a performance difference between i++ and ++i
++a = b 操作未显示错误,但 a++ = b 在使用 g++ 编译时显示错误。两个变量都在这些操作之前初始化。 虽然这些操作没有实际用途,但我认为它们在编译时应该会出现相同的错误。你怎么认为?如
在this fiddle ,为什么计数器在调用 increment() 函数时不增加。已将计数器设置为增加对自身的分配后分配,因此在单击事件按钮(多次)后,计数器变量应该增加。 注意:如果我像这样进行
尝试在 iOS 中使用 swift 使用 firebase FieldValue.increment(1) 时,我收到编译器错误。该错误仅表示“‘增量’的使用不明确” 我已将所有 Pod 更新为所有使
我修复了 this question 中的代码这样它就可以编译: #define text (); #define return &argv;return int *** emphasized ()
我需要将每个增量 id 设置为前一个生成的 id 表的增量 id +5。这意味着每次自动增量必须有 5 个间隙。像这个系列2、7、12、17等.. 任何想法请分享。 最佳答案 请检查链接: https
我正在尝试进行设置,将类从 1 增加到 12,并根据变量列表(也是 12 个变量)设置背景颜色。 我很接近,但没有得到我所希望的。这是我第一次涉足 SASS 中的控制指令,所以请原谅我的无知。 目前,
我有以下代码 int cnt = 0; for (int i = 0; i 0 和 N(N-1)/2当所有 a[k] == 0 时。 对于增量的总数,为外部 for 循环添加 N 为
我们有一个方法可以维护我们应用程序中所有事件的全局序列索引。由于它是网站,因此预计具有线程安全的这种方法。线程安全的实现如下: private static long lastUsedIndex =
我有这个简单的表(仅用于测试): create table table ( key int not null primary key auto_increment, name varchar(30)
我见过很多不错的对象池实现。例如:C# Object Pooling Pattern implementation . 但似乎线程安全的总是使用锁,从不尝试使用 Interlocked.* 操作。 编
在 jQuery 中增加值的最佳方法是什么 .data()目的? 最佳答案 这看起来有点奇怪,但根据文档 .data()将所有数据字段作为对象返回,因此您可以直接更改其值: $('#id').data
是 Interlocked.Increment(ref x)比 x++ 快或慢对于各种平台上的整数和多头? 最佳答案 它较慢,因为它强制操作以原子方式发生,并且充当内存屏障,消除了处理器围绕指令重新排
我创建了一个购物车应用。当用户单击同一产品时,我要增加编号。 如果用户单击同一项目10次,则我想这样更新Firestore。 items:[{'productId':'1234','count':10
我需要循环遍历数据数组并为每个数组值打印一个“递增”字母。我知道我可以做到这一点: $array = array(11, 33, 44, 98, 1, 3, 2, 9, 66, 21, 45); //
Firestore 的 FieldValue.increment(someValue) 可以与其他字段正常配合使用,但不能与 map 配合使用。 我正在尝试增加 map 中属性的值。我有一个名为用户的
如果行的faction.factionname 与 INSERT 的 cards.faction 匹配,我正在尝试创建一个触发器,在 INSERT into card 之后增加派系表中的 cardco
我们有一个并发的多线程程序。我如何使样本数每次增加 +5 间隔? Interlocked.Increment 是否有间隔过载?我没有看到它列出。 Microsoft Interlocked.Incre
我正在运行时创建动态类型,目的是从该类型创建/序列化/反序列化对象,然后绑定(bind)到网格控件。一切正常,但我用数据库中的记录更新属性的方式很可悲。我从某个地方粘贴了这个 setter 生成器,当
我是一名优秀的程序员,十分优秀!