成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

一個簡單express+jade+mysql+bootstrap+nodejs的demo

sherlock221 / 802人閱讀

摘要:迅速發(fā)展,目前最熱的構建框架非莫屬,在上有的就可以證明。下面就以為中心構建一個前后端都包含在內的簡單吧。簡單的能讓你迅速地了解到工作流程。創(chuàng)建并初始化項目首先,進入到你的工作目錄新建一個項目目錄并打開通過命令為你的項目創(chuàng)建一個文件。

Nodejs迅速發(fā)展,目前最熱的Nodejs構建框架非express莫屬,在Github上有32k的star就可以證明。下面就以Nodejs為中心構建一個前后端都包含在內的簡單demo吧。

不管開發(fā)什么項目,有了腳手架之后不管對于理解還是開發(fā)都會變得容易。簡單的demo能讓你迅速地了解到工作流程。廢話不多說,開始構建吧!

1、安裝和配置環(huán)境
1.1、 安裝Node.js與NPM
Windows下安裝 Node.js 還是比較方便的,請自行下載并安裝, 安裝包及源碼下載地址為: https://nodejs.org/en/download/ 。安裝過程傻瓜式一直‘NEXT’就可以。安裝完成后打開命令行輸入node -v返回相應的版本號說明環(huán)境變量配置成功了。
NPM 是隨同 Node.js 一起安裝的包管理器,新版的 Node.js 已經(jīng)集成了 npm ,所以NPM也一并安裝好了。

1.2、創(chuàng)建并初始化項目
首先,進入到你的工作目錄新建一個項目目錄并打開

D:WWW>mkdir nodejs-express-mysql-jade && cd nodejs-express-mysql-jade

通過 npm init 命令為你的項目創(chuàng)建一個 package.json 文件。

D:WWW
odejs-express-mysql-jade>npm init

該命令會要求你輸入一些參數(shù),包括應用名、版本等,可以直接按回車設置為默認值。需要注意的是,其中有一項為 entry point: ,它的值為項目的入口文件,你可以設置成你想要的名稱,例如 app.js 或者 index.js 等,在這兒我就默認選擇了 app.js 。

1.3、安裝express和應用生成器express-generator
通過npm直接安裝生成器express-generator

npm install express express-generator -g

然后使用express [name]或者直接express命令構建一個項目;name是你輸入的文件名,不填就在當前目錄構建。

express

構建完成后的目錄結構:

然后安裝所有的依賴包,如果你寫了上面的[name],那么進入到[name]下目錄后運行npm install,如果沒有寫名字,在當前目錄直接運行npm install。

npm install

1.4、運行項目

運行命令

set DEBUG=myapp & npm start

然后在瀏覽器中打開 http://localhost:3000/ 網(wǎng)址就可以看到這個應用了。

當然每次更新代碼都要重執(zhí)行一次命令顯得效率低,安裝nodemon

npm install nodemon -g

修改package.json:

  "scripts": {
    "start": "set DEBUG=myapp & nodemon ./bin/www"
  },

之后每次只要更新了文件,服務器都會自動更新并啟動了,直接去頁面刷新即可。

到這里第一步的構建工作已經(jīng)結束了。

2、連接后臺

2.1、安裝mysql并連接數(shù)據(jù)庫

npm install mysql -g

安裝包之后在項目根目錄下新建兩個目錄如下圖紅色框所示

在本地建一個數(shù)據(jù)庫user,并建一張user表,然后加入三個字段id、name、age;

其中conf.js:

// MySQL數(shù)據(jù)庫聯(lián)接配置
module.exports = {
    mysql: {
        host: "localhost", 
        user: "root",
        password: "",
        database:"user", // 前面建的user表位于這個數(shù)據(jù)庫中
        port: 3306
    }
};

userSqlMapping.js:

var user = {
    insert:"INSERT INTO user(name, age) VALUES(? , ?)",
    update:"UPDATE user SET name = ?, age = ? WHERE id = ?",
    delete: "DELETE FROM user WHERE id=?",
    queryById: "SELECT * FROM user WHERE id=?",
    queryAll: "SELECT * FROM user"
};

module.exports = user;

userDao.js:

// 實現(xiàn)與MySQL交互
var mysql = require("mysql");
var $conf = require("../conf/conf");
// var $util = require("../util/util");
var $sql = require("./userSqlMapping");

// 使用連接池,提升性能
var pool = mysql.createPool( $conf.mysql );

// 向前臺返回JSON方法的簡單封裝
var jsonWrite = function (res, ret) {
    if(typeof ret === "undefined") {
        res.json({
            code:"1",
            msg: "操作失敗"
        });
    } else {
        res.json(ret);
    }
};

module.exports = {
    add: function (req, res, next) {
        pool.getConnection(function(err, connection) {
            // 獲取前臺頁面?zhèn)鬟^來的參數(shù)
            var param = req.query || req.params;

            // 建立連接,向表中插入值
            // "INSERT INTO user(id, name, age) VALUES(0,?,?)",
            connection.query($sql.insert, [param.name, param.age], function(err, result) {
                if(result) {
                    result = {
                        code: 200,
                        msg:"增加成功"
                    };    
                }
                // 以json形式,把操作結果返回給前臺頁面
                jsonWrite(res, result);
                // 釋放連接 
                connection.release();
            });
        });
    },
    delete: function (req, res, next) {
        // delete by Id
        pool.getConnection(function(err, connection) {
            console.log(req.query.id);
            var id = +req.query.id;
            connection.query($sql.delete, id, function(err, result) {
                if(result.affectedRows > 0) {
                    jsonWrite(res, result);
                    result = {
                        code: 200,
                        msg:"刪除成功"
                    };
                } else {
                    result = void 0;
                }
                jsonWrite(res, result);
                connection.release();
            });
        });
    },
    updateUser: function (req, res, next) {
        var param = req.body;
        console.log(param);
        if(param.name == null || param.age == null) {
            jsonWrite(res, undefined);
            return;
        }
        pool.getConnection(function(err, connection) {
            connection.query($sql.update, [param.name, param.age, param.id], function(err, result) {
                // 使用頁面進行跳轉提示
                // if(result.affectedRows) {
                //     res.render("suc",{
                //         title:"成功頁",
                //         result: result
                //     });                     // 第二個參數(shù)可以直接在jade中使用
                // } else {
                //     res.render("fail",  {
                //         result: result
                //     });
                // }
                jsonWrite(res, result);
                connection.release();
            });
        });
    },
    queryById: function (req, res, next) {
        var id = +req.query.id;                     // 為了拼湊正確的sql語句,這里要轉下整數(shù)
        pool.getConnection(function(err, connection) {
            connection.query($sql.queryById, id, function(err, result) {
                jsonWrite(res, result);
                connection.release();
            });
        });
    },
    queryAll: function (req, res, next) {
        pool.getConnection(function(err, connection) {
            connection.query($sql.queryAll, function(err, result) {
                // jsonWrite(res, result);
                res.render("list",{
                    title:"列表頁",
                    result:result
                });
                connection.release();
            });
        });
    }
};

2.2、更新路由
編輯routes/users.js

var express = require("express");
var router = express.Router();
var userDao = require("../dao/userDao");

/* GET users listing. */
router.get("/", function(req, res, next) {
  res.send("respond with a resource");
});
// 增加用戶
router.get("/addUser", function(req, res, next) {
    userDao.add(req, res, next);
});
router.get("/addUserMiddle", function(req, res, next) {
    res.render("addUser",{
        title:"添加用戶頁"
    });
});
//查看全部用戶
router.get("/queryAll", function(req, res, next) {
    userDao.queryAll(req, res, next);
});
//查詢指定用戶
router.get("/query", function(req, res, next) {
    userDao.queryById(req, res, next);
});
//刪除用戶 
router.get("/deleteUser", function(req, res, next) {
    userDao.delete(req, res, next);
});
//更新用戶信息
router.post("/updateUser", function(req, res, next) {
    userDao.updateUser(req, res, next);
});

module.exports = router;

2.3、安裝bootstrap添加對應的視圖文件

安裝bootstrap先安裝bower

npm install bower -g

安裝完了bower之后,編輯.bowerrc文件。能夠把下載的包放在對應的位置上:

{
  "directory" : "public/libs"
}

安裝bootstrap包:

bower install bootstrap

不過最近bower好像一直在維護,這樣的話就用npm安裝bootstrap和jquery包了。

npm install bootstrap@3 --save
npm install jquery --save

安裝完了之后,因為沒用webpack,包模塊管理起來沒那么方便。所以就用gulp直接把包拉到資源目錄public下

npm install gulp -g

在跟package.json同目錄下建一個gulpfile.js文件,輸入以下代碼:

var gulp = require("gulp");

gulp.task("moveJquery" , function(){
    return gulp.src("node_modules/jquery/*/*")
    .pipe(gulp.dest("public/libs/jquery"));
});

gulp.task("moveBootstrap" ,["moveJquery"] ,  function(){
    return gulp.src("node_modules/bootstrap/*/*/*")
    .pipe(gulp.dest("public/libs/bootstrap/"));
});

在命令行輸入:

gulp moveBootstrap

這樣就把node_modules下的包拉到了public/libs下了

最后在layout.jade上引入相應的文件:

doctype html
html
    head
        title #{title}
        link(rel="stylesheet", href="/libs/bootstrap/dist/css/bootstrap.min.css")
        script(src="/libs/jquery/dist/jquery.min.js")
        script(src="/libs/bootstrap/dist/js/bootstrap.min.js")
    body
        block content

其他的視圖就不在這里一一列舉了。

完成全部工作之后,在瀏覽器上輸入localhost:3000/users/queryAll就可以完成如下圖所示的所有操作啦。

運行結果圖:

添加用戶:

編輯用戶信息:

用戶信息列表:

過濾用戶信息,這里只簡單地寫了根據(jù)id過濾,這里不重點講這個:

講到這里,就已經(jīng)講完了。對于剛接觸Nodejs的童鞋來說,這是個蠻不錯的demo。

下次繼續(xù)完善前端工具方面的內容。webpack配置熱更新等等。。。這樣在更新完你的代碼之后直接去頁面就可以看到效果了,連F5都不用按,這些細節(jié)會大大地提高開發(fā)效率。

項目地址:Demo,只想了解流程又不想構建的童鞋直接clone到本地哦。對你有丁點的幫助請給個star哈!

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/83160.html

相關文章

  • 夢幻西游手游煉藥信息采集系統(tǒng)(Node.js+Express+Bower+Bootstrap+Mon

    摘要:后天開題答辯了,報告沒整完做,答完再繼續(xù)做。預祝大家游戲玩的開心,代碼寫的順心。先把這第一版放出來,小弟初學此道,還請大家批評指正如果文中有對廣州網(wǎng)易計算機系統(tǒng)有限公司侵權的行為,請聯(lián)系我,立馬刪文。 夢幻西游手游煉藥信息采集系統(tǒng) 一、初衷 本文不是軟文?。?!本文不是軟文?。?!本文不是軟文?。?!文章開始重要的事情說三遍?。?!初中時玩一款網(wǎng)易的游戲叫《夢幻西游》,前兩天看朋友在玩《夢幻西...

    Hegel_Gu 評論0 收藏0
  • 個人博客主頁搭建隨筆

    摘要:博主目前的這個項目還不算很大,模塊依賴簡單,但期望完成諸如版本號替換,壓縮代碼,合并文件,發(fā)布到服務器等和模塊化關系不大的工作,所以使用了。同時,對和附加緩存,配合和版本號實現(xiàn)服務器更新,這一部分其實已經(jīng)幫我們實現(xiàn)好了。 經(jīng)常在各種論壇、博客還有 github 上活躍的朋友不難發(fā)現(xiàn),許多大牛都有自己的網(wǎng)站,也多以博客為主。博主作為一個立志前端的大白,難道不應該和大牛學習么?說干就干,前...

    whjin 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<