關(guān)于JS控制代碼暫停的實(shí)現(xiàn)方法分享
更新時(shí)間:2012年10月11日 23:08:46 作者:
關(guān)于JS控制代碼暫停的工作總結(jié),需要的朋友可以參考下
方法一:這是在網(wǎng)上找的一個(gè)方法,可以用。但說實(shí)話,這個(gè)方法我不怎么明白。。。寫得好復(fù)雜。這樣做跟setTimeout能有多大區(qū)別?
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");
}
}
方法二:這也是在網(wǎng)上找的,可以用。它的原理是先彈出一個(gè)窗口,因?yàn)镴S在彈出窗口時(shí),代碼會(huì)在當(dāng)前位置暫停執(zhí)行。等過了一段時(shí)間后再執(zhí)行關(guān)閉窗口函數(shù),代碼繼續(xù)執(zhí)行。這中方法非常簡單,但令人討厭的是它會(huì)彈出一個(gè)窗口。。。
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);
}
方法三:這個(gè)方法是我自己寫的。因?yàn)槲乙獙?shí)現(xiàn)的功能比較復(fù)雜,要循環(huán)調(diào)用getpath()方法。而前面的兩種方法都只能應(yīng)用在順序執(zhí)行的代碼段中,無法控制循環(huán)。在這里我采用了前后臺結(jié)合的方法。在前臺通過Ajax調(diào)用后臺方法,直接將線程掛起1s,成而實(shí)現(xiàn)JS代碼強(qiáng)制暫停。
前臺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);
}
以上僅供大家參考,歡迎吐槽!
復(fù)制代碼 代碼如下:
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");
}
}
方法二:這也是在網(wǎng)上找的,可以用。它的原理是先彈出一個(gè)窗口,因?yàn)镴S在彈出窗口時(shí),代碼會(huì)在當(dāng)前位置暫停執(zhí)行。等過了一段時(shí)間后再執(zhí)行關(guān)閉窗口函數(shù),代碼繼續(xù)執(zhí)行。這中方法非常簡單,但令人討厭的是它會(huì)彈出一個(gè)窗口。。。
復(fù)制代碼 代碼如下:
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);
}
方法三:這個(gè)方法是我自己寫的。因?yàn)槲乙獙?shí)現(xiàn)的功能比較復(fù)雜,要循環(huán)調(diào)用getpath()方法。而前面的兩種方法都只能應(yīng)用在順序執(zhí)行的代碼段中,無法控制循環(huán)。在這里我采用了前后臺結(jié)合的方法。在前臺通過Ajax調(diào)用后臺方法,直接將線程掛起1s,成而實(shí)現(xiàn)JS代碼強(qiáng)制暫停。
前臺JS:
復(fù)制代碼 代碼如下:
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:
復(fù)制代碼 代碼如下:
if (methodname == "Sleep" )//休眠
{
int time = int .Parse(req["Time"].ToString());
System.Threading. Thread.Sleep(time);
}
以上僅供大家參考,歡迎吐槽!
您可能感興趣的文章:
- JS實(shí)現(xiàn)程序暫停與繼續(xù)功能代碼解讀
- JS控制按鈕自動(dòng)切換背景顏色(可暫停)
- 用Javascript實(shí)現(xiàn)Sleep暫停功能代碼
- javascript實(shí)現(xiàn)的像java、c#之類的sleep暫停的函數(shù)代碼
- javascript中巧用“閉包”實(shí)現(xiàn)程序的暫停執(zhí)行功能
- Javascript中暫停功能的實(shí)現(xiàn)代碼
- jquery中animate的stop()方法作用實(shí)例分析
- jQuery實(shí)現(xiàn)帶滾動(dòng)線條導(dǎo)航效果的方法
- jQuery及JS實(shí)現(xiàn)循環(huán)中暫停的方法
相關(guān)文章
.NET微信公眾號開發(fā)之創(chuàng)建自定義菜單
這篇文章主要介紹了.NET微信公眾號開發(fā)之創(chuàng)建自定義菜單的相關(guān)資料,需要的朋友可以參考下2015-07-07
JavaScript+html實(shí)現(xiàn)前端頁面滑動(dòng)驗(yàn)證(2)
這篇文章主要為大家詳細(xì)介紹了JavaScript+html實(shí)現(xiàn)前端頁面滑動(dòng)驗(yàn)證的第二種方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06
JavaScript常見的函數(shù)中的屬性與方法總結(jié)
當(dāng)定義和調(diào)用函數(shù)時(shí),JavaScript?函數(shù)對象會(huì)自動(dòng)具有一些特定的屬性,本文為大家總結(jié)了一些常見的屬性和方法,感興趣的小伙伴可以了解一下2023-05-05
使用canvas實(shí)現(xiàn)魔法攝像頭的示例代碼
我們用手機(jī)的攝像頭自拍,很容易實(shí)現(xiàn)簡單的自拍效果,如復(fù)古、黑白等等,其實(shí)我們使用web端的JavaScript也是可以實(shí)現(xiàn)的,接下來就帶領(lǐng)小伙伴實(shí)現(xiàn)一個(gè)魔法攝像頭,并且提供了截圖下載功能,需要的朋友可以參考下2023-08-08
微信小程序bindtap與catchtap的區(qū)別詳解
本文主要介紹了微信小程序bindtap與catchtap的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
JavaScript實(shí)現(xiàn)前端倒計(jì)時(shí)效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)前端倒計(jì)時(shí)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-02-02
在JavaScript中查找字符串中最長單詞的三種方法(推薦)
這篇文章主要介紹了在JavaScript中查找字符串中最長單詞的三種方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01

