【北京網(wǎng)站制作】基于Node.js、Express、Jscex開發(fā)的ToDo網(wǎng)站實例
  • 更新時間:2024-11-07 00:22:26
  • 網(wǎng)站建設
  • 發(fā)布時間:1年前
  • 481

基于Node.js、Express和Jscex開發(fā)的ToDo網(wǎng)站示例

Jscex的主要使用場景是“JavaScript異步編程”,但無論是運行在瀏覽器端還是服務器端都沒有限制。 Node.js 最近很火,Windows 原生版本也剛剛發(fā)布。很多同學會用它來制作一些網(wǎng)站之類的小程序。目前用Node.js開發(fā)網(wǎng)站最著名的框架就是Express,而且比較好用。前段時間在CNodeJS社區(qū)看到一篇文章。有同學將一個用Python寫的ToDo列表網(wǎng)站移植到了Node.js上。為了推廣Jscex,我fork了這個項目,修改為基于Jscex的版本。大家可以來對比一下。當然這個站點太簡單了,我也在尋找更合適的項目。 (網(wǎng)站制作)

51CTO推薦話題:Node.js專區(qū)

JavaScript是一種非阻塞語言,所以各種API都設計成異步的,有利于服務端的擴展性和客戶端網(wǎng)頁的響應性,但是在編程中會遇到各種問題。比如ToDo例子中一個簡單的處理函數(shù),因為需要查詢數(shù)據(jù)庫,所以需要寫一個回調:

exports.index=function(req,res,next){

db.query('select*fromtodoorderbyfinishedasc,idasclimit50',function(err,rows){

if(err)returnnext(err);

res.render('index',{todos:rows});

});

};

db變量用于操作MySQL數(shù)據(jù)庫。它的查詢方法傳入sql(可能有參數(shù)),并提供回調函數(shù)來提示錯誤或返回查詢結果。在回調中,我們必須判斷err是否存在,如果存在,則調用next向框架報告“error”。每個異步操作都必須是這樣的。試想一下,如果在這個查詢之后還有一個查詢,需要進行嵌套和err判斷。每一個處理函數(shù)都是如此,這也是異步編程的煩惱之一:很難進行統(tǒng)一的異常處理,處理代碼總是需要分散在各處。一不小心就會變成“野外異常”,很難排查。

我只是Jscexed ToDo 網(wǎng)站。首先,啟用MySQL 查詢以訪問Jscex (libjscex.mysql.js):

alt">exports.jscexify?=?function?(db)?{ ?
  • ????db.queryAsync?=?function?()?{ ?
  • ????????var?_this?=?this; ?
  • ?
  • ????????var?args?=?[]; ?
  • ????????for?(var?i?=?0;?i?<?arguments.length;?i++)?{ ?
  • ????????????args.push(arguments[i]); ?
  • ????????} ?
  • ?
  • ????????var?delegate?=?{ ?
  • ????????????onStart:?function?(callback)?{ ?
  • ?
  • ????????????????args.push(function?(err,?result)?{ ?
  • ????????????????????if?(err)?{ ?
  • ????????????????????????callback("failure",?err); ?
  • ????????????????????}?else?{ ?
  • ????????????????????????callback("success",?result); ?
  • ????????????????????} ?
  • ????????????????}); ?
  • ?
  • ????????????????_this.query.apply(_this,?args); ?
  • ????????????} ?
  • ????????}; ?
  • ?
  • ????????return?new?Jscex.Async.Task(delegate); ?
  • ????} ?
  • }?
  • 一般來說,將一個異步接口給Jscex化并不需要那么多代碼(最關鍵的其實只是onStart函數(shù))。這里近30行代碼,其中大部分是為了支持“變長”參數(shù),因此queryAsync函數(shù)會保留調用時的所有參數(shù),補上一個callback,再去調用query函數(shù)本身。此時,便可以去改寫之前的index等處理函數(shù)了(controllerstodo.js),例如:

    1. exports.index?=?toHandler(eval(Jscex.compile("async",?function?(req,?res)?{ ?
    2. ?
    3. ????var?todos?=?$await(db.queryAsync('select?*?from?todo?order?by?finished?asc,?id?asc?limit?50')); ?
    4. ????res.render("index",?{?todos:?todos?}); ?
    5. ?
    6. })));?

    toHandler函數(shù)的作用,是將一個“接受req和res,返回Task”的函數(shù),封裝成標準的“接受req、res和next三個參數(shù)”的處理函數(shù),并提供統(tǒng)一的錯誤處理:

    1. var?toHandler?=?function?(asyncFunc)?{ ?
    2. ????return?function?(req,?res,?next)?{ ?
    3. ????????var?task?=?asyncFunc(req,?res); ?
    4. ????????task.addListener(function?()?{ ?
    5. ????????????if?(task.status?==?"failed")?{ ?
    6. ????????????????next(task.error); ?
    7. ????????????} ?
    8. ????????}); ?
    9. ????????task.start(); ?
    10. ????} ?
    11. }?

    我在todo.js里保留了原有各個處理函數(shù)的實現(xiàn),感興趣的朋友可以對比一下它們之前的差別??上У氖?,由于ToDo實在過于簡單,Jscex的優(yōu)勢并沒有表現(xiàn)出來太多。例如,每個處理程序中只有一個MySQL查詢,沒有判斷和循環(huán),更別說為了充分利用IO并發(fā)能力,從而組合多個異步函數(shù)了。因此,我最近也一直在尋找更復雜一些的示例,不過似乎用Express的開源網(wǎng)站并不多見,我?guī)缀醵枷胱约簩懸粋€了。目前感覺Nodepad似乎還算不錯,接下來可能會對它下手。

    ToDo網(wǎng)站依賴Express,ejs和MySQL驅動,同時我把Jscex作為添加為它的子模塊。如果您要克隆一份ToDo的代碼把玩一番,可以:

    1. >?git?clone?git://github.com/JeffreyZhao/todo.git ?
    2. >?cd?todo ?
    3. >?git?submodule?init ?
    4. >?git?submodule?update ?
    5. >?npm?install?express?ejs?mysql ?
    6. >?node?server.js?

    從現(xiàn)在開始,我會在InfoQ中文站上發(fā)表一系列關于Jscex的文章,既有關于瀏覽器端的JavaScript開發(fā),也有在服務器端利用Node.js開發(fā)的內容??赡苣壳斑€可能會有所疑惑,例如為什么要使用危險的eval函數(shù),eval和Jscex.compile函數(shù)不能封裝起來嗎?其實在看了我的文章并對Jscex有了基本了解之后,就會發(fā)現(xiàn)這些都是以“傳統(tǒng)眼光”來看待Jscex時所形成的誤解。Jscex的做法的確“另辟蹊徑”,否則在JavaScript異步類庫已經(jīng)多如牛毛的情況下,我不知如何讓它脫穎而出。(高端網(wǎng)站建設)

    我們專注高端建站,小程序開發(fā)、軟件系統(tǒng)定制開發(fā)、BUG修復、物聯(lián)網(wǎng)開發(fā)、各類API接口對接開發(fā)等。十余年開發(fā)經(jīng)驗,每一個項目承諾做到滿意為止,多一次對比,一定讓您多一份收獲!

    本文章出于推來客官網(wǎng),轉載請表明原文地址:https://www.tlkjt.com/web/13823.html
    推薦文章

    在線客服

    掃碼聯(lián)系客服

    3985758

    回到頂部