0

私はこのJavascriptを以下に持っています

FireFoxでの作業でやりたい各送信後に5秒の遅延を維持したかった

<html>
 <head>
 <script type="text/javascript">
function sleep(ms)
    {
        var dt = new Date();
        dt.setTime(dt.getTime() + ms);
        while (new Date().getTime() < dt.getTime());
    }

function test() {
var windowCounter = 1; 
var myStringArray = [ "user1", "user2" , "user3" , "user4" ]
var len = myStringArray.length;
for (var i=0; i<3; ++i) {
document.inform.cid = myStringArray[i];
document.inform.pwd = "xxxxxxxx";
   document.inform.target = windowCounter++; // a different target each time
    document.inform.submit();
}
}
</script>
 </head>
 <body >
  <form name="inform"   target="newWin" action="https://www.google.co.in/">
<input type="text" name="cid"  />
<input type="hidden" name="pwd"  />
 <input type="hidden" name="throttle" value="999" />
    <input type="submit" value="go" onclick="test()">
  </form>
 </body>
</html>

各送信後に手動でスリープ状態を維持しようとしましたが、 setTimeOut を使用してみましたが、何も機能していません。

誰でも私を助けてくれませんか

編集部分

<html>
<head>
<script type="text/javascript">
  var interval = window.setInterval(iterate, 5000);
var myStringArray = ["user1", "user2", "user3", "user4"];

  function iterate() {
 iterate.arr = iterate.arr || myStringArray.slice(0);

    //if it still has elements left
    if(iterate.arr.length > 0) {
        document.inform.cid = iterate.arr.pop(); //remove the top one
alert(document.inform.cid);
        document.inform.pw = "xxxx";
        document.inform.target = iterate.arr.length; // a different target each time - length of the arr
        document.inform.submit();
    } else {
        window.clearInterval(interval); //no more left cancel it
    }
};

</script>
</head>
<body>
 <form name="inform" method="get"  target="newWin" action="https://www.google.co.in/">
  <input type="text" name="cid" />
<input type="password" name="pw" />
<input type="hidden" name="throttle" value="999" />
    <input type="submit" value="go" onclick="iterate()"/>
  </form>
</body>
</html>
4

2 に答える 2

2

次のようなものを使用できますか(ただし、テストされていません):

    var interval = window.setInterval(iterate, 5000);
    var myStringArray = ["user1", "user2", "user3", "user4"];

function iterate() {
    iterate.arr = iterate.arr || myStringArray.slice(0); //set a private array to cache

    //if it still has elements left
    if(iterate.arr.length > 0) {
    //thought there was more than one formon the page - but if only one then we can reference by its name - cid

        ///:document.inform.cid = iterate.arr.pop(); //remove the top one
    iterate.arr.pop();
        document.inform.pwd = "xxxxxxxx";
        document.inform.target = iterate.arr.length; // a different target each time - length of the arr
        document.inform.submit();
    } else {
        window.clearInterval(interval); //no more left cancel it
    }


};
于 2012-11-07T04:04:45.067 に答える
0

Plaeseはこれを試してみてください:

<html>
     <head>
     <script type="text/javascript">
    function submit()
        {
             document.inform.submit();
        }

    function test() {
     setTimeout('submit()',5000);
     }
    </script>
     </head>
     <body >
      <form name="inform"  target="newWin"  action="https://www.google.co.in/">
    <input type="text" name="cid"  />
    <input type="hidden" name="pwd"  />
     <input type="hidden" name="throttle" value="999" />
        <input type="button" value="go" onclick="test()">
      </form>
     </body>
    </html>
于 2012-11-07T04:13:30.013 に答える