方法一:這是在網上找的一個方法,可以用。但說實話,這個方法我不怎麼明白。。。寫得好復雜。這樣做跟setTimeout能有多大區別?
復制代碼 代碼如下:
function Pause(obj, iMinSecond) {
if (window.eventList == null ) window.eventList = new Array();
var ind = -1;
for (var i = 0; i < window.eventList.length; i++) {
if (window.eventList[i] == null ) {
window.eventList[i] = obj;
ind = i;
break;
}
}
if (ind == -1) {
ind = window.eventList.length;
window.eventList[ind] = obj;
}
setTimeout( "GoOn(" + ind + ")" , iMinSecond);
}
function GoOn(ind) {
var obj = window.eventList[ind];
window.eventList[ind] = null;
if (obj.NextStep) obj.NextStep();
else obj();
}
function testJsStop() {
alert( "1");
Pause( this, 3000);
this.NextStep = function () {
alert( "2");
}
}
方法二:這也是在網上找的,可以用。它的原理是先彈出一個窗口,因為JS在彈出窗口時,代碼會在當前位置暫停執行。等過了一段時間後再執行關閉窗口函數,代碼繼續執行。這中方法非常簡單,但令人討厭的是它會彈出一個窗口。。。
復制代碼 代碼如下:
function pause(numberMillis) {
addcloud();
var dialogScript = 'window.setTimeout(' + ' function () { $("#bgDiv").remove(); }, ' + numberMillis + ');';
var result = window.showModalDialog('javascript:document.writeln(' + '"<script>' + dialogScript + '<' + '/script>")' );
}
function test() {
var a = 0;
alert(a);
pause(5000);
a = 999;
alert(a);
}
方法三:這個方法是我自己寫的。因為我要實現的功能比較復雜,要循環調用getpath()方法。而前面的兩種方法都只能應用在順序執行的代碼段中,無法控制循環。在這裡我采用了前後台結合的方法。在前台通過Ajax調用後台方法,直接將線程掛起1s,成而實現JS代碼強制暫停。
前台JS:
復制代碼 代碼如下:
function getpath() {
var time = 1000;
$.ajaxSettings.async = false;
$.getJSON( "../Actions/TspHandler.ashx?rKey=" + parseInt(Math.random() * 999 + 1).toString() + "&opKey=Sleep"
+ "&Time=" + time,
null,
function (json) {
});
..........
}
後台ashx:
復制代碼 代碼如下:
if (methodname == "Sleep" )//休眠
{
int time = int .Parse(req["Time"].ToString());
System.Threading. Thread.Sleep(time);
}
以上僅供大家參考,歡迎吐槽!