从Javascript中的setTimeout函数中更新对象的属性值
updating attribute value of a object from within a setTimeout function in Javascript
我对下面的代码片段有问题。
var flag = { f: 0 };
setTimeout(function(flag) {
flag.f+=1;
}, duration, flag);
while(flag.f == 0);
alert("Asd");
"Asd"不会被警告。页面在一段时间后崩溃。怎么了?
Settimeout停止其余代码的执行。Settimeout将运行,然后while循环将运行,因此它永远不会执行。
这是实际发生的事情的一个非常简化的版本。查看更多信息:
http://ejohn.org/blog/how-javascript-timers-work/编辑:在更好地理解你的问题之后,似乎这就是你要找的:
var flag = { f: 0 };
setTimeout(function(flag) {
flag.f+=1;
afterMove()
}, duration, flag);
function afterMove() {
alert("move is done!");
}
相关文章:
- 如何从对象的原型方法访问JavaScript对象属性
- 如何将数组项添加到对象属性中
- 设置嵌套对象属性的更好方法
- JavaScript管理具有重复属性名称的对象属性
- 如何使用element.myobj.prop等具有对象属性的元素
- 如何使用(this)访问Angular 2 http rxjs catch函数中的对象属性
- Es6:能够在设置/更新/删除对象属性时调用自定义方法
- 如何在AngularJS工厂中正确声明对象属性
- 如何使用object.assign()从其他对象引用基本对象属性
- 使用XPath样式访问Javascript JSON对象属性
- 将javascript对象(属性+值)合并到一个对象中
- 数组:使对象属性成为数组键
- 无法从JavaScript中的函数调用对象属性
- Google Closure Advanced |无法识别对象属性|动态属性
- Javascript从匿名函数访问外部对象属性
- 从函数更改对象属性
- 如何从字符串变量访问对象属性
- 从嵌套对象属性中获取排除某个值的最高值
- 在Aurelia computeds中,当设置依赖关系时,如何声明对对象属性的依赖关系
- 传递数量不确定的可能嵌套的对象属性