国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

后臺管理系統(tǒng)相關(guān)

paulquei / 1865人閱讀

摘要:將數(shù)據(jù)經(jīng)由寫入到數(shù)據(jù)庫中上兩步的文件創(chuàng)建完畢之后,將其部署到服務(wù)器上。數(shù)據(jù)取回至通過上面的可以將數(shù)據(jù)拿回至,現(xiàn)在需要將數(shù)據(jù)經(jīng)由,再將其發(fā)送到前端頁面上,需要在中設(shè)置相關(guān)路由。

FE-Nodejs-PHP-database

本demo主要實現(xiàn)的功能是使用前端表格輸入相關(guān)數(shù)據(jù),將數(shù)據(jù)通過Ajax請求發(fā)送至nodejs中,在經(jīng)由php發(fā)送至數(shù)據(jù)庫中,然后在從數(shù)據(jù)庫中通過php將數(shù)據(jù)取出,經(jīng)由nodejs發(fā)送至頁面中。nodejs起中間件的作用。
主要使用的技術(shù)有:

前端頁面:html5、CSS3、JavaScript;

nodejs:express框架、swig模板;

php:封裝類,查詢、插入數(shù)據(jù)。

開始準(zhǔn)備工作 創(chuàng)建項目文件夾-FEtoBE:

在命令行使用npm init 初始化項目文件夾,填寫項目名稱等一系列,或者一路enter,結(jié)束后項目文件會出現(xiàn)一個新文件package.json,就是剛才填寫的或默認(rèn)的數(shù)據(jù)。

前端-數(shù)據(jù)庫 創(chuàng)建寫入數(shù)據(jù)頁面

在FEtoBE 文件夾下創(chuàng)建 viewspublic 文件夾,在views文件夾下創(chuàng)建add_data.html文件,作為寫入數(shù)據(jù)的窗口,此處,創(chuàng)建了一個表格,模擬補習(xí)班四個課程每天新增報名人數(shù),以及總的報名人數(shù)。總體效果如下圖所示(未做兼容性及美化):
表格文件在Github上。

數(shù)據(jù)傳輸經(jīng)過nodejs 安裝相應(yīng)插件模板等

此步的總體流程為:給表格中的按鈕“點擊添加”添加事件,使其通過點擊事件,發(fā)送Ajax請求,將表格中的數(shù)據(jù)通過get方法傳輸?shù)絅ode某路由中。
所以此處需要創(chuàng)建node文件,并使用express 模板來創(chuàng)建相應(yīng)路由(保證電腦中已安裝node)。

在命令行中,安裝express: npm install express --save;

安裝swig模板:npm install express --save;

FEtoBE文件夾下創(chuàng)建 app.js 文件,并引入express以及swigpath

此時文件結(jié)構(gòu):

配置相應(yīng)路由等

繼續(xù)在app.js中書寫,配置模板引擎,node模板引擎文件位置:

//配置模板引擎為 html,作用是告訴node模板引擎文件位置  
app.set("views","./views/");
app.set("view engine","html");
app.engine("html", swig.renderFile);
// 設(shè)置靜態(tài)文件路徑
app.use(express.static(path.join(__dirname, "public")));

繼而設(shè)置路由,用來接受add_data.html傳來的數(shù)據(jù),以及端口:

// 設(shè)置添加數(shù)據(jù)界面的路由
app.get("/adding", function(req, res) {
    res.render("add_data")
});

//設(shè)置路由,接收數(shù)據(jù)
app.get("/addData", function(req, res) {
    console.log(req.query.mathNum);//驗證是否成功傳輸數(shù)據(jù)
})
//設(shè)置端口
var server = app.listen(3000, function() {
    var host = server.address().address;
    var port = server.address().port;
    console.log("Example app listening at http://%s:%s", host, port);
});
設(shè)置ajax發(fā)送表格數(shù)據(jù)

此時,需要的add_data.html文件中,使用ajax來發(fā)送數(shù)據(jù):

當(dāng)上兩步完成之后,在命令行中啟動:node app.js,在瀏覽器中輸出之前設(shè)置的添加數(shù)據(jù)界面的路由,本例中為“ http://localhost:3000/adding ”,可以看到瀏覽器中已經(jīng)展示了表格,輸入數(shù)據(jù)之后,點擊按鈕,就可以在命令行中看到測試的數(shù)據(jù)顯示出來。說明我們已經(jīng)可以將數(shù)據(jù)從前端界面穿輸入nodejs中,下一步即時從nodejs傳輸入php,在經(jīng)php最終傳入數(shù)據(jù)庫。

PHP文件

通過封裝一個數(shù)據(jù)庫類,實現(xiàn)數(shù)據(jù)庫的增加、查找等(此處在xampp中的默認(rèn)路徑創(chuàng)建database文件夾)。

創(chuàng)建封裝類:

創(chuàng)建DB.php 文件,創(chuàng)建封裝類。具體代碼:在Github中查看。

創(chuàng)建寫入數(shù)據(jù)的php文件

創(chuàng)建get.php文件。本文件的作用是將nodejs中傳來的數(shù)據(jù)寫入到數(shù)據(jù)庫中。所以此時數(shù)據(jù)庫中應(yīng)該有相應(yīng)接收數(shù)據(jù)的表格(此處為forfetobe數(shù)據(jù)庫下的classData 數(shù)據(jù)表格)。

具體代碼:在Github中查看。

將數(shù)據(jù)經(jīng)由php寫入到數(shù)據(jù)庫中

上兩步的php文件創(chuàng)建完畢之后,將其部署到服務(wù)器上。需要使用 request模塊在nodejs中進(jìn)行http請求。
首先進(jìn)行安裝:npm install request --save,在app.js中引入此模塊:var request = require("request");
所以可以在接收數(shù)據(jù)的路由中addData中添加request請求,將數(shù)據(jù)發(fā)送到get.php中,再由其發(fā)送到相應(yīng)數(shù)據(jù)庫中:

// 設(shè)置路由,用來接受add_data.html傳來的數(shù)據(jù)
app.get("/addData", function(req, res) {
    var responseData =
        "mathNum=" + req.query.mathNum + "&" +
        "等等。。。。。。";
    //此處注意傳輸?shù)膔esponseData應(yīng)該為字符串形式,且格式與get請求在瀏覽器地址欄的格式相一致。  
        request("http://localhost/database/get.php?" + responseData, function(error, response, body) {

    });
})

具體代碼在Github上查看。
此時,打開相應(yīng)服務(wù),表格中添加數(shù)據(jù),即可以傳輸?shù)綌?shù)據(jù)庫中的相應(yīng)數(shù)據(jù)表里。

數(shù)據(jù)庫-前端

上一節(jié)文章中,寫到從前端寫入的數(shù)據(jù),經(jīng)由Nodejs傳給php,在由php寫入到數(shù)據(jù)庫中。本節(jié)文章主要寫從數(shù)據(jù)庫將數(shù)據(jù)拿出來展示到前端去(繼續(xù)上一節(jié)的demo)。

php文件獲取數(shù)據(jù)庫數(shù)據(jù)

上一節(jié)中封裝了一個PDO類,也就是DB.php文件。創(chuàng)建此類的一個實例,用來查詢數(shù)據(jù)庫中的數(shù)據(jù)。
依舊是在xampp中的默認(rèn)路徑創(chuàng)建database文件夾下,新建back.php,進(jìn)行數(shù)據(jù)庫相應(yīng)數(shù)據(jù)表的查詢,具體代碼:在GitHub上 查看。

數(shù)據(jù)取回至Nodejs

通過上面的php可以將數(shù)據(jù)拿回至php,現(xiàn)在需要將數(shù)據(jù) 經(jīng)由nodejs,再將其發(fā)送到前端頁面上,需要在app.js中設(shè)置相關(guān)路由。

設(shè)置數(shù)據(jù)展示界面路由
//設(shè)置路由,用來將數(shù)據(jù)展示到頁面中去
app.get("/showing", function(req, res) {
    res.render("show_data")
});

這個沒啥說的,和上一篇中的設(shè)置數(shù)據(jù)寫入界面路由相同。都是設(shè)置在views文件夾下新建相應(yīng)的html文件,此處是show_data.html

設(shè)置php發(fā)送到nodejs上的路由
//設(shè)置路由,作用是將來自‘show_data.html’的ajax請求,并將數(shù)據(jù)庫中的數(shù)據(jù)通過PHP發(fā)送至此
app.get("/showData", function(req, res) {
        var responseData =
            "mathNum=" + req.query.mathNum + "&" +
            //等等
request("http://localhost/database/back.php?" + responseData, function(error, response, body) {
        res.json(body);//必須。將數(shù)據(jù)吐出。
    });
    });

現(xiàn)在即需要書寫show_data.html界面,接收數(shù)據(jù)。
此處需要在public文件夾下創(chuàng)建scriptscssimages等文件夾來存放相應(yīng)的靜態(tài)資源文件。在將靜態(tài)文件 .css.jsimg放入到public文件夾下的相應(yīng)路徑中去。
此時項目文檔結(jié)構(gòu)為:

引入路徑為:

//show_data.html文件內(nèi)的樣式文件引入路徑展示。

在書寫完整體的展示界面后,(詳細(xì)代碼在:GitHub上查看), 就需要將數(shù)據(jù)傳輸?shù)巾撁嬷腥ァ?/p> 數(shù)據(jù)展示到頁面中去:

在相應(yīng)的位置書寫ajax請求,將showData 路由上的數(shù)據(jù)發(fā)送到頁面:

$(function() {
  $.ajax({
    url: "http://localhost:3000/showData",
    dataType: "json",
    success: function(point) {
      var jsondata = JSON.parse(point);
      var datalength = jsondata.length;
      //提取數(shù)據(jù)庫里最近七天內(nèi)的數(shù)據(jù)
      var nowAll = Number(jsondata[datalength - 1]["atotalnum"]);
      var nowIncrease = Number(jsondata[datalength - 1]["aincreasenum"]);
         //。。。
      var sevenAll = Number(jsondata[datalength - 7]["atotalnum"]);
      var sevenIncrease = Number(jsondata[datalength - 7]["aincreasenum"]);
      //以下是使用highcharts 創(chuàng)建表格。
      //具體代碼在Github上查看。
})

至此,一個完整的將前端數(shù)據(jù)通過ajax的get方式發(fā)送到Nodejs中,在經(jīng)由php發(fā)送到數(shù)據(jù)庫中,然后再從數(shù)據(jù)庫中拿取最新的數(shù)據(jù),展示到界面中。
整個的展示流程為:

進(jìn)入登錄界面

其中輸入錯誤的密碼或未注冊的用戶名均會得到提示:

查看展示界面

查看展示界面,沒門課程均有多帶帶的展示界面 以及相應(yīng)的數(shù)據(jù)。且是響應(yīng)式,適合在手機端瀏覽。還可以在左側(cè)的功能欄找到添加數(shù)據(jù)接口。

添加數(shù)據(jù)

添加成功后點擊確認(rèn) 添加按鈕,即可在展示界面查看最新數(shù)據(jù)。

整個的流程就是:

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

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/88523.html

相關(guān)文章

  • 基于vue模塊化開發(fā)后臺系統(tǒng)——構(gòu)建項目

    摘要:構(gòu)建完成,那么就開始擼代碼了文章項目效果預(yù)覽地址項目開源代碼基于模塊化開發(fā)后臺系統(tǒng)準(zhǔn)備工作基于模塊化開發(fā)后臺系統(tǒng)構(gòu)建項目基于模塊化開發(fā)后臺系統(tǒng)權(quán)限控制 文章目錄如下:項目效果預(yù)覽地址項目開源代碼基于vue模塊化開發(fā)后臺系統(tǒng)——準(zhǔn)備工作基于vue模塊化開發(fā)后臺系統(tǒng)——構(gòu)建項目基于vue模塊化開發(fā)后臺系統(tǒng)——權(quán)限控制 前言 在熟悉上一篇說到準(zhǔn)備工具之后,現(xiàn)在開始構(gòu)建屬于自己的項目,這是一個...

    joyqi 評論0 收藏0
  • 基于vue模塊化開發(fā)后臺系統(tǒng)——構(gòu)建項目

    摘要:構(gòu)建完成,那么就開始擼代碼了文章項目效果預(yù)覽地址項目開源代碼基于模塊化開發(fā)后臺系統(tǒng)準(zhǔn)備工作基于模塊化開發(fā)后臺系統(tǒng)構(gòu)建項目基于模塊化開發(fā)后臺系統(tǒng)權(quán)限控制 文章目錄如下:項目效果預(yù)覽地址項目開源代碼基于vue模塊化開發(fā)后臺系統(tǒng)——準(zhǔn)備工作基于vue模塊化開發(fā)后臺系統(tǒng)——構(gòu)建項目基于vue模塊化開發(fā)后臺系統(tǒng)——權(quán)限控制 前言 在熟悉上一篇說到準(zhǔn)備工具之后,現(xiàn)在開始構(gòu)建屬于自己的項目,這是一個...

    zqhxuyuan 評論0 收藏0
  • 基于vue模塊化開發(fā)后臺系統(tǒng)——構(gòu)建項目

    摘要:構(gòu)建完成,那么就開始擼代碼了文章項目效果預(yù)覽地址項目開源代碼基于模塊化開發(fā)后臺系統(tǒng)準(zhǔn)備工作基于模塊化開發(fā)后臺系統(tǒng)構(gòu)建項目基于模塊化開發(fā)后臺系統(tǒng)權(quán)限控制 文章目錄如下:項目效果預(yù)覽地址項目開源代碼基于vue模塊化開發(fā)后臺系統(tǒng)——準(zhǔn)備工作基于vue模塊化開發(fā)后臺系統(tǒng)——構(gòu)建項目基于vue模塊化開發(fā)后臺系統(tǒng)——權(quán)限控制 前言 在熟悉上一篇說到準(zhǔn)備工具之后,現(xiàn)在開始構(gòu)建屬于自己的項目,這是一個...

    YanceyOfficial 評論0 收藏0
  • vue2+element 管理后臺 集成解決方案 沒有沒做的,只要想不到的!

    摘要:目前的技術(shù)棧主要的采用由于是個人項目,所以數(shù)據(jù)請求都是用了代替。后續(xù)會出一系列的教程配套文章,如如何從零構(gòu)建后臺項目框架,如何做完整的用戶系統(tǒng)如權(quán)限驗證,二次登錄等,如何二次開發(fā)組件如富文本,如何整合七牛等等文章,各種后臺開發(fā)經(jīng)驗等等。 完整項目地址:vue-element-admin系類文章一:手摸手,帶你用vue擼后臺 系列一(基礎(chǔ)篇)系類文章二:手摸手,帶你用vue擼后臺 系列二...

    sanyang 評論0 收藏0

發(fā)表評論

0條評論

paulquei

|高級講師

TA的文章

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