功能无限循环并忽略其他功能的部分

时间:2016-03-17 17:59:33

标签: javascript greasemonkey

好的,所以基本上我写的这个脚本都是清楚的,如果文本框已满,请单击一个按钮,如果不是则刷新页面。

我可以成功地清除文本框,当它没有时刷新页面,但是当我尝试使用我的clickButton函数时,它会进入无限循环并跳过clrLog中的if()



function addFunction(func, exec) {
  var script = document.createElement('script');
  script.textContent = '-' + func + (exec ? '()' : '');
  document.body.appendChild(script);
  document.body.removeChild(script);
}
function clickButton(val) {
  buttons = document.getElementsByTagName('INPUT');
  for (var i = 0; i < buttons.length; i++)
  {
    if (buttons[i].type == 'submit' && buttons[i].value == val)
    {
      buttons[i].click();
    }
  }
}
function clrLog() {
  var elements = [
  ];
  elements = document.getElementsByClassName('logarea');
  if (elements.log.value === '')
  setTimeout(function () {
    location.reload();
  }, 5000);
  for (var i = 0; i < elements.length; i++) {
    elements[i].value = '';
  }
  clickButton('Edit log file');
}
function main() {
  addFunction(clrLog(), true);
}
main();
&#13;
&#13;
&#13;

1 个答案:

答案 0 :(得分:3)

我发现通过使用document.querySelector()可以避免使用for循环;相反 - 更容易:)