2 回答

TA貢獻(xiàn)1805條經(jīng)驗(yàn) 獲得超9個(gè)贊
如果能從backend所用的語(yǔ)言和framework上入手會(huì)簡(jiǎn)單得很多。
很多(不怎么流行的)web framework都是基于continuation的,比如Smalltalk的Seaside,Python的Nagare,等等。這些framework通常都利用了語(yǔ)言本身提供的保存當(dāng)前continuation的功能,使得服務(wù)器端的函數(shù)可以在運(yùn)行中途暫時(shí)停止,將函數(shù)運(yùn)行的狀態(tài)serialize到數(shù)據(jù)庫(kù)中,等前端返回新的信息時(shí)再將保存的函數(shù)狀態(tài)恢復(fù),繼續(xù)運(yùn)行。這樣做的好處是運(yùn)行的流程沒(méi)有受到太大的影響,程序員可以很容易地就適應(yīng)這種寫(xiě)法。
另一種不需要語(yǔ)言和framework支持的方式則需要刻意將每一步的狀態(tài)都保存到數(shù)據(jù)庫(kù)里。這樣做的話,可以通過(guò)session或者其他的方式來(lái)保存狀態(tài)。缺點(diǎn)是代碼寫(xiě)起來(lái)不那么符合一般運(yùn)行的流程,不夠直觀。

TA貢獻(xiàn)1820條經(jīng)驗(yàn) 獲得超10個(gè)贊
你問(wèn)題中的示例情景,建議以:前端與用戶交互問(wèn)答,保存用戶回答數(shù)據(jù),到最后一步一次性提交的方式來(lái)實(shí)現(xiàn)。
如果在每次問(wèn)答都需提交驗(yàn)證一次數(shù)據(jù)的場(chǎng)景中,我們就得知道:web client 與 server 的交互是無(wú)狀態(tài)的,因此,服務(wù)端對(duì)客戶端的身份識(shí)別,必然需要一個(gè)憑證,來(lái)做為雙方數(shù)據(jù)交互的基礎(chǔ)。這個(gè)憑證可以使用 cookie 來(lái)保存,讓真正的數(shù)據(jù)保存在服務(wù)端。
你也可以這么做,把數(shù)據(jù)保存在JS對(duì)象中,到最后一步來(lái)驗(yàn)證
//狀態(tài)對(duì)象 var obj = { a1: false, a2: false, a3: false } //綁定用戶輸入完成事件,提交數(shù)據(jù) $.ajax({ url: "http://ooxx.cn/a1", success:function(a1){ obj.a1 = a1 } }); $.ajax({ url: "http://ooxx.cn/a2", success:function(a2){ obj.a2 = a2 } }); $.ajax({ url: "http://ooxx.cn/a2", success:function(a3){ obj.a2 = a3; //驗(yàn)證有效性 if(obj.a1 && obj.a2 &&obj.a3){ console.log('ok'); } }
- 2 回答
- 0 關(guān)注
- 318 瀏覽
添加回答
舉報(bào)