setTimeout【注:out的'o'是小写】
如果setTimeout(function,mill)中的function带参数,则定义的毫秒树mill会失效,function方法会立即执行
解决方法:把参数定义为"全局变量"进行操作,或者不要单独写一个方法,直接再同一个方法内直接写function函数,例如本例中的第一个setTimeout;
例子1:
var operations =[Object object,Object object,Object object,Object object,Object object];
function sessionPlayback(){
playControl(0);
}
function playControl(i){
var operation = operations[i];
var content = $("#operation_content").val();
content+="#>"+operation.request;
$("#operation_content").val(content);
setTimeout(function(){
var content = $("#operation_content").val();
content+= operation.response+"\r\n";
$("#operation_content").val(content);
},eval((operation.endTime - operation.startTime)*playSpeed));
i ++;
if(i<operations.length){
var jiangetime = 0;
jiangetime = (operations[i].startTime - operations[i-1].startTime)*playSpeed;
console.log("jiangetime:"+jiangetime);
setTimeout("playControl("+i+")",jiangetime);
}
}
例子2:
function playControl(){
console.log("operations:"+operations);
$("#operation_content").val("");
for(var i = 0;i < operations.length;i++){
var jiangetime = 0;
if(i>0){
jiangetime = operations[i].startTime - operations[0].startTime;
}
console.log("jiangetime:"+jiangetime);
setTimeout("showOperationHistory(operations["+i+"])",jiangetime);
}
$("#operation_content").focus();
}
function showOperationHistory(operation){
var content = $("#operation_content").val();
content+="#>"+operation.request+"\r\n";//加换行
console.log("--------------------");
$("#operation_content").val(content);
setTimeout(function(){
var content = $("#operation_content").val();
content+= operation.response+"\r\n";
$("#operation_content").val(content);
},eval(operation.endTime - operation.startTime));
}
传递的参数尽量是字符串!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。