[北京網站制作]基于Node.js、Express和Jscex開發(fā)的ToDo網站示例
基于Node.js、Express和Jscex開發(fā)的ToDo網站示例
Jscex的主要使用場景是“JavaScript異步編程”,不過并沒有限制是跑在瀏覽器還是服務器端。最近Node.js很火熱,也剛發(fā)布了原生的Windows版,不少同學會用它來做一些網站這樣的小程序。目前用Node.js開發(fā)網站最著名的框架是Express,使用起來也是比較容易的。前段時間看到CNodeJS社區(qū)的一篇文章,有同學將一個Python寫的ToDo列表網站移植到了Node.js上,我為了推廣Jscex,就fork了這個項目,將其修改為基于Jscex的版本,大伙兒可以來比較一下。當然這個網站過于簡單,我也正在尋找更合適的項目。(網站制作)
51CTO推薦專題:Node.js專區(qū)
JavaScript是一個沒有阻塞特性的語言,因此各類API都會設計為異步,這對于服務器的伸縮性和客戶端網頁的響應能力都有好處,不過在程序編寫上就會遇到各種問題了。例如在ToDo示例中的一個簡單的處理函數,因為需要查詢數據庫,就要寫成帶回調的樣子:
- exports.index = function (req, res, next) {
- db.query('select * from todo order by finished asc, id asc limit 50', function (err, rows) {
- if (err) return next(err);
- res.render('index', { todos: rows });
- });
- };
db變量用來操作MySQL數據庫,它的query方法傳入sql(可能還會有參數)并提供一個回調函數,用來提示錯誤或是返回查詢結果。在回調中我們必須判斷err是否存在,如果存在便調用next報告框架“出錯了”。每個異步操作都必須如此,試想如果在這個查詢后還有另一個查詢,則還需要進行一次嵌套和err判斷。每個處理函數都是如此,這也是異步編程的煩惱之一:難以進行統一的異常處理,處理代碼總是需要分散在各處,一不小心就變成“野異常”,還很難排查出來。
我將ToDo網站簡單地Jscex化了一下。首先讓MySQL的查詢能夠接入Jscex(libjscex.mysql.js):
- 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函數)。這里近30行代碼,其中大部分是為了支持“變長”參數,因此queryAsync函數會保留調用時的所有參數,補上一個callback,再去調用query函數本身。此時,便可以去改寫之前的index等處理函數了(controllerstodo.js),例如:
- exports.index = toHandler(eval(Jscex.compile("async", function (req, res) {
- var todos = $await(db.queryAsync('select * from todo order by finished asc, id asc limit 50'));
- res.render("index", { todos: todos });
- })));
toHandler函數的作用,是將一個“接受req和res,返回Task”的函數,封裝成標準的“接受req、res和next三個參數”的處理函數,并提供統一的錯誤處理:
- var toHandler = function (asyncFunc) {
- return function (req, res, next) {
- var task = asyncFunc(req, res);
- task.addListener(function () {
- if (task.status == "failed") {
- next(task.error);
- }
- });
- task.start();
- }
- }
我在todo.js里保留了原有各個處理函數的實現,感興趣的朋友可以對比一下它們之前的差別??上У氖?,由于ToDo實在過于簡單,Jscex的優(yōu)勢并沒有表現出來太多。例如,每個處理程序中只有一個MySQL查詢,沒有判斷和循環(huán),更別說為了充分利用IO并發(fā)能力,從而組合多個異步函數了。因此,我最近也一直在尋找更復雜一些的示例,不過似乎用Express的開源網站并不多見,我?guī)缀醵枷胱约簩懸粋€了。目前感覺Nodepad似乎還算不錯,接下來可能會對它下手。
ToDo網站依賴Express,ejs和MySQL驅動,同時我把Jscex作為添加為它的子模塊。如果您要克隆一份ToDo的代碼把玩一番,可以:
- > git clone git://github.com/JeffreyZhao/todo.git
- > cd todo
- > git submodule init
- > git submodule update
- > npm install express ejs mysql
- > node server.js
從現在開始,我會在InfoQ中文站上發(fā)表一系列關于Jscex的文章,既有關于瀏覽器端的JavaScript開發(fā),也有在服務器端利用Node.js開發(fā)的內容。可能您目前還可能會有所疑惑,例如為什么要使用危險的eval函數,eval和Jscex.compile函數不能封裝起來嗎?其實在看了我的文章并對Jscex有了基本了解之后,就會發(fā)現這些都是以“傳統眼光”來看待Jscex時所形成的誤解。Jscex的做法的確“另辟蹊徑”,否則在JavaScript異步類庫已經多如牛毛的情況下,我不知如何讓它脫穎而出。(高端網站建設)
推薦新聞
更多行業(yè)-
導致個人網站失敗的6個原因
北京網站建設公司尚品中國:個人站長在互聯網大潮中起到至關重要的作用,正...
2012-04-11 -
網站建設時網站地圖設計要注意哪些細節(jié)問題
一旦你選擇了一個有才華的高端網站定制團隊來幫助你創(chuàng)建新網站,你和你的創(chuàng)...
2020-04-02 -
長尾時代的核心主題
北京網站設計公司尚品中國:經過前面分析發(fā)現,在一個沒有貨架空間的限制和...
2012-08-23 -
簡潔而規(guī)范的代碼在營銷型網站建設中不可或缺
對于一般公司而言,在網站建設的時候更關心的多半是網站設計,或者更深入一...
2013-11-14 -
Internet的基本內容
一、Internet是什么因特網是Internet音譯和意譯的組合,也...
2014-07-24 -
網站設計建設的定制對網站今后的發(fā)展非常關鍵
免費獲得一個商業(yè)網站聽起來不錯,但大多數模板中臃腫的代碼實際上損害了你...
2020-04-08
預約專業(yè)咨詢顧問溝通!
免責聲明
非常感謝您訪問我們的網站。在您使用本網站之前,請您仔細閱讀本聲明的所有條款。
1、本站部分內容來源自網絡,涉及到的部分文章和圖片版權屬于原作者,本站轉載僅供大家學習和交流,切勿用于任何商業(yè)活動。
2、本站不承擔用戶因使用這些資源對自己和他人造成任何形式的損失或傷害。
3、本聲明未涉及的問題參見國家有關法律法規(guī),當本聲明與國家法律法規(guī)沖突時,以國家法律法規(guī)為準。
4、如果侵害了您的合法權益,請您及時與我們,我們會在第一時間刪除相關內容!
聯系方式:010-60259772
電子郵件:394588593@qq.com