• <li id="0bn34"><legend id="0bn34"><th id="0bn34"></th></legend></li>

      <label id="0bn34"><mark id="0bn34"><strong id="0bn34"></strong></mark></label>
      <span id="0bn34"><optgroup id="0bn34"></optgroup></span> <label id="0bn34"><mark id="0bn34"><strong id="0bn34"></strong></mark></label>

      <rt id="0bn34"></rt>
      <span id="0bn34"><optgroup id="0bn34"><center id="0bn34"></center></optgroup></span>
      <li id="0bn34"><big id="0bn34"><listing id="0bn34"></listing></big></li>
      【北京網站制作】基于Node.js、Express、Jscex開發的ToDo網站實例
      • 更新時間:2025-06-07 12:23:36
      • 網站建設
      • 發布時間:2年前
      • 1037

      基于Node.js、Express和Jscex開發的ToDo網站示例

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

      51CTO推薦話題:Node.js專區

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

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

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

      alt">exports.jscexify?=?function?(db)?{ ?
    1. ????db.queryAsync?=?function?()?{ ?
    2. ????????var?_this?=?this; ?
    3. ?
    4. ????????var?args?=?[]; ?
    5. ????????for?(var?i?=?0;?i?<?arguments.length;?i++)?{ ?
    6. ????????????args.push(arguments[i]); ?
    7. ????????} ?
    8. ?
    9. ????????var?delegate?=?{ ?
    10. ????????????onStart:?function?(callback)?{ ?
    11. ?
    12. ????????????????args.push(function?(err,?result)?{ ?
    13. ????????????????????if?(err)?{ ?
    14. ????????????????????????callback("failure",?err); ?
    15. ????????????????????}?else?{ ?
    16. ????????????????????????callback("success",?result); ?
    17. ????????????????????} ?
    18. ????????????????}); ?
    19. ?
    20. ????????????????_this.query.apply(_this,?args); ?
    21. ????????????} ?
    22. ????????}; ?
    23. ?
    24. ????????return?new?Jscex.Async.Task(delegate); ?
    25. ????} ?
    26. }?
    27. 一般來說,將一個異步接口給Jscex化并不需要那么多代碼(最關鍵的其實只是onStart函數)。這里近30行代碼,其中大部分是為了支持“變長”參數,因此queryAsync函數會保留調用時的所有參數,補上一個callback,再去調用query函數本身。此時,便可以去改寫之前的index等處理函數了(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函數的作用,是將一個“接受req和res,返回Task”的函數,封裝成標準的“接受req、res和next三個參數”的處理函數,并提供統一的錯誤處理:

      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里保留了原有各個處理函數的實現,感興趣的朋友可以對比一下它們之前的差別。可惜的是,由于ToDo實在過于簡單,Jscex的優勢并沒有表現出來太多。例如,每個處理程序中只有一個MySQL查詢,沒有判斷和循環,更別說為了充分利用IO并發能力,從而組合多個異步函數了。因此,我最近也一直在尋找更復雜一些的示例,不過似乎用Express的開源網站并不多見,我幾乎都想自己寫一個了。目前感覺Nodepad似乎還算不錯,接下來可能會對它下手。

      ToDo網站依賴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?

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

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

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

      在線客服

      掃碼聯系客服

      3985758

      回到頂部

      亚洲明星合成图综合区在线| 天天拍拍夜夜出水| 免费a级毛片18以上观看精品 | 天堂а√在线中文在线| 中文精品久久久久国产网址| 日韩精品在线一区二区| 亚洲欧美日韩精品高清| 熟妇人妻一区二区三区四区| 国产精品国产三级国产专播| www.日韩在线| 成人在线观看免费| 久久精品久久久久观看99水蜜桃| 欧美XXXXXBBBB| 亚洲欧美综合视频| 欧美一级专区免费大片俄罗斯| 亚洲熟妇丰满多毛XXXX| 欧美xxxxx在线观看| 亚洲一区二区三区播放在线 | 亚洲乱码在线播放| 欧美久久久久久| 亚洲精品免费在线观看| 欧美精选欧美极品| 免费一级欧美大片在线观看| 欧美老人巨大xxxx做受视频| 亚洲欧美日韩综合久久| 最近中文字幕mv2018免费看| 亚洲人配人种jizz| 欧洲mv日韩mv国产mv| 亚洲AV无码AV制服另类专区| 日韩电影免费在线观看网| 久久婷婷五月综合97色一本一本| 日韩aⅴ人妻无码一区二区| 五月婷婷开心综合| 日韩乱码中文字幕视频| 亚洲av日韩av不卡在线观看| 日韩精品免费一区二区三区| 久久国产精品免费一区 | 日本19禁啪啪无遮挡免费动图| 久久精品福利视频| 最近韩国免费观看hd电影国语| 亚洲欧美日韩国产精品专区|