国产视频在线观看一区I97人人艹I久久福利电影I久久综合视频网I国产在线观看99I亚州人成在线播放I91亚洲精品久久久

首頁 > 新聞 > 知識賦能

[北京網站制作]基于Node.js、Express和Jscex開發的ToDo網站示例

2011-10-24 5724
分享至:

基于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示例中的一個簡單的處理函數,因為需要查詢數據庫,就要寫成帶回調的樣子:

  1. exports.index = function (req, res, next) {  
  2.     db.query('select * from todo order by finished asc, id asc limit 50'function (err, rows) {  
  3.         if (err) return next(err);  
  4.         res.render('index', { todos: rows });  
  5.     });  
  6. }; 

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

我將ToDo網站簡單地Jscex化了一下。首先讓MySQL的查詢能夠接入Jscex(libjscex.mysql.js):

  1. exports.jscexify = function (db) {  
  2.     db.queryAsync = function () {  
  3.         var _this = this;  
  4.  
  5.         var args = [];  
  6.         for (var i = 0; i < arguments.length; i++) {  
  7.             args.push(arguments[i]);  
  8.         }  
  9.  
  10.         var delegate = {  
  11.             onStart: function (callback) {  
  12.  
  13.                 args.push(function (err, result) {  
  14.                     if (err) {  
  15.                         callback("failure", err);  
  16.                     } else {  
  17.                         callback("success", result);  
  18.                     }  
  19.                 });  
  20.  
  21.                 _this.query.apply(_this, args);  
  22.             }  
  23.         };  
  24.  
  25.         return new Jscex.Async.Task(delegate);  
  26.     }  

一般來說,將一個異步接口給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.     }  

我在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異步類庫已經多如牛毛的情況下,我不知如何讓它脫穎而出。(高端網站建設)

來源聲明:

本文章系尚品中國編輯原創或采編整理,如需轉載請注明來自尚品中國。以上內容部分(包含圖片、文字)來源于網絡,如有侵權,請及時與本站聯系(010-60259772)。

立即預約專屬顧問 開啟數字化轉型之旅!

10年+資深項目經理1V1服務 | 行業定制化方案 | 精準報價體系
獲取策劃方案
立即預約專屬顧問 開啟數字化轉型之旅!

咨詢我們,獲得專業的服務和報價

聯系我們,免費獲取項目方案及報價,或只是聊一聊您的項目? 在收到您的需求留言后我們將由專業人員于24小時內與您取得聯系,請您保持電話暢通!

  • 科研院所解決方案
  • 外貿出海解決方案
  • 協會學會解決方案
  • 集團上市公司解決方案
  • 生物醫藥解決方案
  • 制造業解決方案
  • 高校教育解決方案
  • 信創網站改造解決方案
更多服務咨詢,請聯系尚品

010-60259772

您的姓名 *
您的電話 *
您的郵箱
公司名稱 *
主站蜘蛛池模板: 天天骑夜夜操 | a久久| 成人97在线观看免费高清 | 亚洲精品久久久一区二区三区 | 亚洲性69影院在线观看 | 插下面视频 | 欧美一区二区三 | 欧美性猛交xxxx乱大交极品 | 欧美第一页草草影院 | 日本一级成人毛片免费观看 | 精品视频手机在线观看免费 | 全部免费国产潢色一级 | 99热久久这里只精品国产9 | 成人亚洲一区二区色情无码潘金莲 | 一区二区精品 | 国产精品2020观看久久 | 精品偷拍被偷拍在线观看 | 五月丁香国产在线视频 | 亚洲国产av一区二区三区 | 二区欧美 | 精品国产一区二区三区四区五区 | 欧美日韩精品国产一区二区 | 超碰97人人做人人爱2020 | 亚洲精品一区二区三区在线 | 欧美日韩亚洲视频 | 成人免费毛片网站 | 亚洲男人av天堂午夜在 | 国产区免费 | 亚洲国产精品久久久久爰色欲 | 欧美亚洲国产一区 | 国产欧美精品一区二区三区-老狼 | 亚洲日本人成中文字幕 | 国产亚洲精品美女久久久久 | 欧美一区二区黄 | 乱色熟女综合一区二区三区 | 人人爽人人爽 | 国产成人av无码精品 | 国产噜噜在线视频观看 | 国产情侣一区二区 | av网站在线免费观看 | 免费一级毛片在线播放欧美 | 婷婷视频在线观看 | 漂亮人妻被黑人久久精品 | 男人用嘴添女人下身免费视频 | 精产国品一二三产区m553麻豆 | 日本不卡一区二区 | 国产69精品久久久久99尤物 | 亚洲精品少妇30p | 久久狠狠 | 久久精品国产99久久久古代 | 国产永久视频 | 婷婷成人综合激情在线视频播放 | 五月婷婷欧美 | 亚洲视频观看 | 乱码精品一区二区三区 | 日韩在线观看视频一区 | 日韩av午夜在线观看 | 欧美视频性 | 久久精品视频网站 | 亚洲综合伊人久久综合 | 国产乱子伦精品无码专区 | 精品无人乱码一区二区三区 | 国产在线精品一区二区三区直播 | 国产69久久久欧美黑人A片 | 色一情一区二区三区四区 | 成人爽a毛片在线视频 | jizz性欧美2 日本不卡在线 | 精品日本一区二区三区在线观看 | 国产精品麻豆视频 | 国产好爽…又高潮了毛片 | 不卡中文字幕在线 | 国产精品videossex久久发布 | 亚洲乱码一二三四区 | 国产又色又爽无遮挡免费动态图 | 99热官网 | 美女18禁一区二区三区视频 | 天天噜日日噜夜夜噜 | 日韩无套无码精品 | 国产青草视频在线观看 | www午夜视频 | 久久久久无码国产精品一区 | 久久夜色精品国产亚洲 | 中文无码热在线视频 | 欧美卡一卡二卡新区网站 | 日韩精品乱码av一区二区 | 精品欧美一区二区在线观看 | 国产精品视频一区二区三区无码 | 国产精品久久久久久久久久 | 婷婷精品国产一区二区三区日韩 | 亚洲视频在线观看 | 国产免费丝袜调教视频 | 亚洲国产精品毛片av不卡在线 | 亚洲女久久久噜噜噜熟女 | 久久精品黄aa片一区二区三区 | 在线观看国产 | 大肉大捧一进一出好爽动态图 | 欧美经典剧情系列h版在线观看 | 精品久久久久久免费影院 | 手机在线看片 |