Javascript:等待条件为真的非阻塞方式

前端之家收集整理的这篇文章主要介绍了Javascript:等待条件为真的非阻塞方式前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有几个ASP.NET UpdatePanel,每个都有一个AsyncPostBackTrigger绑定到同一个按钮的服务器端点击事件.由于一次只有一个UpdatePanel可以执行其操作,因此我使用PageRequestManager的.get_isInAsyncPostBack()来防止用户在异步回发完成之前能够访问页面的其他部分.

页面的另一部分需要连续动态更新多个更新面板.由于更新面板使用异步触发器,因此调用__doPostBack(“<%= ButtonName.ClientID%>”,“PanelId”);不知所措.因此,它将快速移动到循环的下一次迭代并尝试更新下一个面板.但是,第二次迭代失败,因为已有另一个更新面板执行异步回发.

理想情况下,有一种方法可以等到.get_isInAsyncPostBack()返回false而不阻塞其他客户端活动.

研究让我遇到了很多有问题的人,几乎所有人都被建议使用setTimeOut().我不认为这对我有用.我不想在执行函数之前等待指定的时间.我只是希望我的Javascript在另一个脚本运行时等待,最好等到特定条件为真.

我知道很多人可能会建议我重新考虑我的模型.它实际上不是我的模型,而是一个交给我们开发团队的模型,目前这个团队一直处于混乱状态.由于时间限制,重写模型不是一种选择.唯一的选择是使这项工作.我想如果我有办法使客户端代码无阻塞地等待,我的问题就会得到解决.

解决方法

在javascript中没有诸如等待或睡眠之类的功能,因为它会阻止浏览器响应.

在你的情况下,我会采取类似以下的东西:

function wait(){
  if (!condition){
    setTimeout(wait,100);
  } else {
    // CODE GOES IN HERE
  }
}

猜你在找的JavaScript相关文章