javascript中實現(xiàn)這個功能的是來自BOM的一 " /> 久久er99热精品一区二区,中国老太婆xxxxx,国产99久久九九免费精品无码

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript異步編程

就好像排隊,前面的人忙著忙著突然上廁所了,后面的人阻塞在這里,因此我們就需要讓前面的人死到一邊去,讓后面的人跟進(jìn)……AJAX就是這個概念,請求還在繼續(xù),但我們還可以做其他事。

Javascript中實現(xiàn)這個功能的是來自BOM的一個函數(shù)setTimeout,但相關(guān)的DOM操作也提供了一系列實現(xiàn)。如XMLHttpRequest對象與script標(biāo)簽的onreadystatechange回調(diào),image的onload與onerror回調(diào),iframe的onload,DOM元素的事件回調(diào),HTML5的跨域消息傳送postMessage,QuickTime與flash對象的加載……

setTimeout的零秒延遲在前些年時間被國內(nèi)宣揚(yáng)得特別厲害,但setTimeout是所有延遲中最慢的,最少要花上10多毫秒,如果用setTimeout來開發(fā)特效,這特效會運(yùn)行得比較慢。下面是一個性能測試:

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
Chromium Safari FirefoxOpera 10.10 Opera 10.50
setTimeout 4.32ms 10.201ms 10.302ms 10.38ms 9.876ms
img.onerror 0.199ms 0.678ms 0.201ms 0.058ms 0.575ms
script.onreadystatechangefailfail fail fail fail
script.onload0.414ms 0.138ms 0.414ms fail fail
xhr.onreadystatechangefail0.622ms fail 0.078ms 0.079ms
self.postMessage0.096ms 0.123ms 0.112ms 0.049ms 0.094ms

為了處理這種異步調(diào)用,Mochikit從Python的Twisted框架借來了Deferred這個類,并用它來處理AJAX的回調(diào)。AJAX的回調(diào)通常有兩種,成功加載時的回調(diào)與請求失敗的回調(diào),IE8的XDomainRequest就有這兩種回調(diào)了,標(biāo)準(zhǔn)瀏覽器的script與image也有這兩種回調(diào),分別稱之為onload與onerror。Mochikit的Deferred實例就內(nèi)置一個數(shù)組,每次包含這兩種回調(diào),依次執(zhí)行。Mochikit這偉大的遺產(chǎn)后來由dojo發(fā)揚(yáng)光大了,至于怎么用,自己google吧。

下面是我的框架對它的應(yīng)用,我已把它整合到我的框架中:
復(fù)制代碼 代碼如下:
<!doctype html>
<html>
<head>
<title>異步操作例子 by 司徒正美</title>
<meta charset="utf-8"/>
<meta content="IE=8" http-equiv="X-UA-Compatible"/>
<meta name="keywords" content="異步操作例子 by 司徒正美" />
<meta name="description" content="異步操作例子 by 司徒正美" />
<%= Javascript_include_tag "dom.js" %>
<%= Javascript_tag "window._token = '#{form_authenticity_token}'" if ActionController::Base.allow_forgery_protection %>
<script type="text/Javascript" charset="utf-8">
dom.ready(function(){
dom.require("ajax");
dom.ajax({method:"post",
async:true,
dataType:"text",
data:{authenticity_token:window._token}
}).next(function(a){
alert(a)
});
dom.jsonp({url:"http://del.icio.us/feeds/json/fans/stomita"}).next(function(json){
alert(json)
}).error(function(e){
alert(e)
});
});
</script>
</head>
<body>
</body>
</html>

后臺:
復(fù)制代碼 代碼如下:
class HomeController < ApplicationController
def index
if request.xhr?
name = params[:name]
puts "-------------"
render :text => "<p>The time is <b>" + DateTime.now.to_s + "</b></p>"
end
end
end

在日本一博客提到這樣一個捕捉異步錯誤的例子:
復(fù)制代碼 代碼如下:
function throwError(){
throw new Error('ERROR');
}
try{
setTimeout(throwError, 3000);
} catch(e){
alert(e);
}

看來try...catch是無法捕捉這種形式的錯誤,window.onerror可以,但好像只有IE與FF支持。如果用Deferred來處理,就簡單了!
復(fù)制代碼 代碼如下:
dom.Deferred.next(function () {
throw new Error("錯誤")
}).wait(1).error(function(e){
alert(e instanceof Error)
});

列隊處理。由于是使用了異步,因此不會阻塞頁面的演染。
復(fù)制代碼 代碼如下:
<!doctype html>
<html>
<head>
<title>異步操作例子 by 司徒正美</title>
<meta charset="utf-8"/>
<meta content="IE=8" http-equiv="X-UA-Compatible"/>
<meta name="keywords" content="異步操作例子 by 司徒正美" />
<meta name="description" content="異步操作例子 by 司徒正美" />
<%= Javascript_include_tag "dom.js" %>
<script type="text/Javascript" charset="utf-8">
dom.require("deferred");
dom.require("query");
dom.ready(function(){
var a = dom("#aaa")[0];
dom.Deferred.loop(10,function(i){
a.innerHTML += i+"<br/>"
});
dom.Deferred.loop(10,function(i){
a.innerHTML += String.fromCharCode(i+97)+"<br/>"
});
dom.Deferred.loop(10,function(i){
a.innerHTML += "司徒正美"+i+"<br/>"
});
});
/*結(jié)果
0
a
司徒正美0
1

司徒正美1
2
c
司徒正美2
3
d
司徒正美3
4
e
司徒正美4
5
f
司徒正美5
6
g
司徒正美6
7
h
司徒正美7
8
i
司徒正美8
9
j
司徒正美9
*/
</script>
</head>
<body>
<div id="aaa"></div>
</body>
</html>

JavaScript技術(shù)javascript異步編程,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 免费撕开胸罩吮胸视频 | 乱亲女H秽乱长久久久 | 久久综合中文字幕佐佐木希 | 伊人久久综合热青草 | 久久re视频这里精品09免费 | 在线精品视频成人网 | 香蕉久久夜色精品国产小说 | 国产在线观看的 | 让人爽到湿的小黄书 | 老熟女重囗味GRANNYBBW | 狠狠色狠狠色综合系列 | 国偷自产AV一区二区三区健身房 | 99久久就热视频精品草 | 在线 国产 欧美 亚洲 天堂 | 亚洲AV久久久噜噜噜久久 | 久久热r在线视频精品 | 日韩成人黄色 | 无码国产成人777爽死在线观看 | 91素人约啪 | 久久精品亚洲牛牛影视 | 91se在线看片国产免费观看 | 扒开胸罩揉她的乳尖视频 | 果冻传媒完整免费网站在线观看 | 伦理片在线线手机版韩国免费观看 | 亚洲欧美中文字幕网站大全 | 国产精品伦理一二三区伦理 | 国产又爽又黄又不遮挡视频 | 久久婷婷色香五月综合激情 | 国产v综合v亚洲欧美大片 | 九九99亚洲精品久久久久 | 男人狂躁进女人免费视频公交 | 我的美女奴隶 | 大地影院在线播放 | 99久久精品免费看国产一区二区 | 亚洲偷自拍精品视频在线观看 | 毛片999 | 父皇轻点插好疼H限 | 国产小视频免费在线观看 | 99久久精品久久久久久清纯 | 国产午夜小视频 | 国产国拍亚洲精品av麻豆 |