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

資訊專欄INFORMATION COLUMN

使用React、Node.js、MongoDB、Socket.IO開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程(一

loonggg / 2452人閱讀

摘要:本項目是對使用開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程。到這里為止沒有遇到多大的坑,最多的往往是拼寫錯誤引起的問題,唯一由于拼寫導(dǎo)致,但不提示錯誤的是我打成了運行的時候服務(wù)器一直沒有響應(yīng),找了好久才找到這個錯誤后篇使用開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程二

本項目是對使用React、Node.js、MongoDB、Socket.IO開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程。

英文原文:Create a character voting app using React, Node.js, MongoDB and Socket.IO
原項目github

學(xué)習(xí)過程

要想系統(tǒng)的學(xué)習(xí)些新東西,網(wǎng)上看了很多代碼片段,但很少有這樣完整的一個系統(tǒng)來學(xué)習(xí),基實我本來是比較偏向Vue的但是看到了這個文章,太全面了,對于想入門的人來說,方方面面都有,有前端,有后端,所以忍不住想把它提供的代碼全敲一遍。敲代碼的過程,雖然只是個抄的過程,但比光看要很很多,有的時候往往看人家代碼的時候,感覺是這樣的,"哦,就是這樣的啊.so easy,不過如此嗎~",但一句一句去敲的時候,感覺就是這樣的,"WTF,這是什么鬼,這個函數(shù)哪里來的,這個庫是干嘛用的,這里這么寫到底是為了什么",所以當你把過程中的這些疑問都搞清楚了,才是真正的提高了,光看很多細節(jié)是注意不到的。

對原有的改動

抄代碼是好,但是最好在原來的基礎(chǔ)上加點自己的相法,所以我做的改動主要有如下

把所有不是用ES6的代碼全部改成ES6的

用數(shù)據(jù)庫從mongodb 改成了mysql

用waterline替換mongoose操作數(shù)據(jù)庫

改動后的代碼,我也全發(fā)布在github上了,還沒改完,我會不定期commit的

https://github.com/papersnake/newdenfaces-es6

改寫的過程和遇到的坑

對ES6學(xué)也的也不深,改了這么多也發(fā)現(xiàn)語法上也只用到了import let const 和=>,希望大家提出更多的改進意見
原文第一步的代碼

原文第一步的改進
var express = require("express");
var path = require("path");
var logger = require("morgan");
var bodyParser = require("body-parser");

var app = express();

app.set("port", process.env.PORT || 3000);
app.use(logger("dev"));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(express.static(path.join(__dirname, "public")));

app.listen(app.get("port"), function() {
  console.log("Express server listening on port " + app.get("port"));
});

改寫后,變成

import express    from "express";
import path       from "path";
import logger     from "morgan";
import bodyParser from "body-parser";

let app = express();

app.set("port",process.env.PORT || 3000);
app.use(logger("dev"));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(express.static(path.join(__dirname, "public")));

app.listen(app.get("port"),() => {
    console.log("Express server listening on port " + app.get("port"));
});

為了能讓它跑起來,要在原有依賴的基礎(chǔ)上添加

npm install --save-dev babel-cli,babel-core,babel-preset-es2015,babel-preset-react,babel-register

有幾個依賴是后面才用到的,我這里一并安裝了
在根目錄新建一個.babelrc文件

{
  "presets": [
    "es2015"
  ]
}

用babel-node server.js 就要以跑起來了

原文第二步分 構(gòu)建系統(tǒng)的改寫

為了節(jié)省篇幅,有些全篇的代碼我就不粘貼,給出連接吧 gulpfile.js

gulp 從3.9.0開始支持babel,但是要把文件名改為gulpfile.babel.js
改寫后的代碼

import gulp from "gulp";
import gutil from "gulp-util";
import gulpif from "gulp-if";
import streamify from "gulp-streamify";
import autoprefixer from "gulp-autoprefixer";
import cssmin from "gulp-cssmin";
import less from "gulp-less";
import concat from "gulp-concat";
import plumber from "gulp-plumber";
import source from "vinyl-source-stream";
import babelify from "babelify";
import browserify from "browserify";
import watchify from "watchify";
import uglify from "gulp-uglify";

const production = process.env.NODE_ENV === "production";

const dependencies = [
    "alt",
    "react",
    "react-router",
    "underscore"
];

/*
 |--------------------------------------------------------------------------
 | Combine all JS libraries into a single file for fewer HTTP requests.
 |--------------------------------------------------------------------------
 */
gulp.task("vendor",()=>
    gulp.src([
        "bower_components/jquery/dist/jquery.js",
        "bower_components/bootstrap/dist/bootstrap.js",
        "bower_components/magnific-popup/dist/jquery.magnific-popup.js",
        "bower_components/toastr/toastr.js"
        ]).pipe(concat("vendor.js"))
          .pipe(gulpif(production,uglify({ mangle:false })))
          .pipe(gulp.dest("public/js"))
    );


/*
 |--------------------------------------------------------------------------
 | Compile third-party dependencies separately for faster performance.
 |--------------------------------------------------------------------------
 */
gulp.task("browserify-vendor", () =>
  browserify()
    .require(dependencies)
    .bundle()
    .pipe(source("vendor.bundle.js"))
    .pipe(gulpif(production, streamify(uglify({ mangle: false }))))
    .pipe(gulp.dest("public/js"))
);

/*
 |--------------------------------------------------------------------------
 | Compile only project files, excluding all third-party dependencies.
 |--------------------------------------------------------------------------
 */
gulp.task("browserify", ["browserify-vendor"], () =>
  browserify("app/main.js")
    .external(dependencies)
    .transform(babelify,{ presets: ["es2015", "react"]}) //注意這里,只有加上presets配置才能正常編譯
    .bundle()
    .pipe(source("bundle.js"))
    .pipe(gulpif(production, streamify(uglify({ mangle: false }))))
    .pipe(gulp.dest("public/js"))
);

/*
 |--------------------------------------------------------------------------
 | Same as browserify task, but will also watch for changes and re-compile.
 |--------------------------------------------------------------------------
 */
gulp.task("browserify-watch", ["browserify-vendor"], () =>{
  var bundler = watchify(browserify("app/main.js", watchify.args));
  bundler.external(dependencies);
  bundler.transform(babelify,{ presets: ["es2015", "react"]});
  bundler.on("update", rebundle);
  return rebundle();

  function rebundle() {
    var start = Date.now();
    bundler.bundle()
      .on("error", function(err) {
        gutil.log(gutil.colors.red(err.toString()));
      })
      .on("end", function() {
        gutil.log(gutil.colors.green("Finished rebundling in", (Date.now() - start) + "ms."));
      })
      .pipe(source("bundle.js"))
      .pipe(gulp.dest("public/js/"));
  }
});


/*
 |--------------------------------------------------------------------------
 | Compile LESS stylesheets.
 |--------------------------------------------------------------------------
 */
gulp.task("styles", () =>
  gulp.src("app/stylesheets/main.less")
    .pipe(plumber())
    .pipe(less())
    .pipe(autoprefixer())
    .pipe(gulpif(production, cssmin()))
    .pipe(gulp.dest("public/css"))
);

gulp.task("watch", () =>{
  gulp.watch("app/stylesheets/**/*.less", ["styles"]);
});

gulp.task("default", ["styles", "vendor", "browserify-watch", "watch"]);
gulp.task("build", ["styles", "vendor", "browserify"]);

由于到現(xiàn)在為止,還沒有做其他工作,所以看不到打包的實際效果, 但是也是要控制臺下運行一下gulp 看看有沒有語法錯誤。

到這里為止沒有遇到多大的坑,最多的往往是拼寫錯誤引起的問題,唯一由于拼寫導(dǎo)致,但不提示錯誤的是

app.use(bodyParser.json());

我打成了

app.use(bodyParser.json);

運行的時候服務(wù)器一直沒有響應(yīng),找了好久才找到這個錯誤

后篇

使用React、Node.js、MongoDB、Socket.IO開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程(二)

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

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/79357.html

相關(guān)文章

  • 使用React、Node.js、MongoDB、Socket.IO開發(fā)角色投票應(yīng)用學(xué)習(xí)過程(二

    摘要:吐完槽,還是開始第十二部分的改動吧,這是開始涉及到數(shù)據(jù)庫了,原文用我用改動就比較大了。后篇使用開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程三 前篇 使用React、Node.js、MongoDB、Socket.IO開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程(一) 這篇主要講一下waterline的初始化,原文用的是mongoose 原文第十二步 一下子就到十二步了,因為原文件中react部分的代碼本來就是用E...

    jsdt 評論0 收藏0
  • 使用React、Node.js、MongoDB、Socket.IO開發(fā)角色投票應(yīng)用學(xué)習(xí)過程(三

    摘要:將就用一下,能實現(xiàn)相同的功能就可以了。的方法可以從返回最大值,但是新版中的不行,只能通過這樣的方式返回最大值。 前篇 使用React、Node.js、MongoDB、Socket.IO開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程(一)使用React、Node.js、MongoDB、Socket.IO開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程(二) 原文第十三步,Express API路由 第一個路由是用來創(chuàng)建角...

    JessYanCoding 評論0 收藏0
  • node技術(shù)棧 - 收藏集 - 掘金

    摘要:異步最佳實踐避免回調(diào)地獄前端掘金本文涵蓋了處理異步操作的一些工具和技術(shù)和異步函數(shù)。 Nodejs 連接各種數(shù)據(jù)庫集合例子 - 后端 - 掘金Cassandra Module: cassandra-driver Installation ... 編寫 Node.js Rest API 的 10 個最佳實踐 - 前端 - 掘金全文共 6953 字,讀完需 8 分鐘,速讀需 2 分鐘。翻譯自...

    王偉廷 評論0 收藏0
  • 【全?!?em>使用Node、Express、Angular、MongoDB構(gòu)建實時問卷調(diào)查應(yīng)用程序

    摘要:鑒于此目的,我決定快速構(gòu)建一個用于此目的的問卷調(diào)查應(yīng)用程序。這將啟動一個服務(wù)器并將應(yīng)用程序部署到該服務(wù)器。圖應(yīng)用程序配置基礎(chǔ)前端這個問卷調(diào)查應(yīng)用程序?qū)ΤR娪脩艚缑婧筒季质褂昧丝蚣堋? 全棧教程。轉(zhuǎn)自 使用 Node.js、Express、AngularJS 和 MongoDB 構(gòu)建一個實時問卷調(diào)查應(yīng)用程序 最近,在向大學(xué)生們介紹 HTML5 的時候,我想要對他們進行問卷調(diào)查,并向他們顯...

    BigTomato 評論0 收藏0

發(fā)表評論

0條評論

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