摘要:本項目是對使用開發(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í)過程。
學(xué)習(xí)過程英文原文:Create a character voting app using React, Node.js, MongoDB and Socket.IO
原項目github
要想系統(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" ] }
原文第二步分 構(gòu)建系統(tǒng)的改寫用babel-node server.js 就要以跑起來了
為了節(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
摘要:吐完槽,還是開始第十二部分的改動吧,這是開始涉及到數(shù)據(jù)庫了,原文用我用改動就比較大了。后篇使用開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程三 前篇 使用React、Node.js、MongoDB、Socket.IO開發(fā)一個角色投票應(yīng)用的學(xué)習(xí)過程(一) 這篇主要講一下waterline的初始化,原文用的是mongoose 原文第十二步 一下子就到十二步了,因為原文件中react部分的代碼本來就是用E...
摘要:將就用一下,能實現(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)建角...
摘要:異步最佳實踐避免回調(diào)地獄前端掘金本文涵蓋了處理異步操作的一些工具和技術(shù)和異步函數(shù)。 Nodejs 連接各種數(shù)據(jù)庫集合例子 - 后端 - 掘金Cassandra Module: cassandra-driver Installation ... 編寫 Node.js Rest API 的 10 個最佳實踐 - 前端 - 掘金全文共 6953 字,讀完需 8 分鐘,速讀需 2 分鐘。翻譯自...
摘要:鑒于此目的,我決定快速構(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)查,并向他們顯...
閱讀 1084·2021-11-25 09:43
閱讀 706·2021-11-22 14:45
閱讀 3833·2021-09-30 09:48
閱讀 1072·2021-08-31 09:41
閱讀 1979·2019-08-30 13:52
閱讀 1986·2019-08-30 11:24
閱讀 1354·2019-08-30 11:07
閱讀 961·2019-08-29 12:15