自分で教えるためにReact Appを構築しましたReact
とNode.js
です。私はcreate-react-appというWebpack
という名前のFacebookで提供されている定型文を使ってアプリケーションをバンドルしています。私は今どこに私はアプリ内でファイルのアップロード機能を作成しようとしているポイントです。私はMulterと呼ばれるものを見つけました.Expressで使用すると、まっすぐ進むファイルのアップロードが可能になりました。私はこれを使用し、私のアプリのファイルアップロード部分のために表現する予定です。ノードとリアクトリーを使った基本的なファイルアップロード
App.js:
import React from 'react';
import testupload from './testupload/testupload';
var App = React.createClass({
testUpload(e) {
e.preventDefault();
testupload();
},
render() {
return (<div className="outer-most-container">
<form encType='multipart/form-data'>
<input type="file" method="post"/>
<button type="submit" onClick={this.testUpload}>submit</button>
</form>
</div>)
}) export default App;
testupload.js:
var express = require('express')
var multer = require('multer')
var upload = multer({
dest: 'uploads/'
})
var app = express()
var testupload = function() {
app.post('/profile', upload.single('avatar'), function(req, res, next) {})
app.post('/photos/upload', upload.array('photos', 12), function(req, res, next) {})
var cpUpload = upload.fields([{
name: 'avatar',
maxCount: 1
}, {
name: 'gallery',
maxCount: 8
}])
app.post('/cool-profile', cpUpload, function(req, res, next) {})
}
export default testupload;
私はときにそれをPHPでの作業に慣れているここで私が達成しようとしているものに以下のコードがあります私のロジックはデフォルトのイベントを防ぐためにボタンをクリックすると、別のスクリプトからインポートされたtestupload
関数を実行します。私は現時点では取得していますエラーが
が未定義
request.js
である
ので、ブラウザのコンソールが言うのプロパティ「プロトタイプ」を読み取ることができませんです。私のアプローチが正しいロジックであるかどうかは分かりませんので、正しい方向へのプッシュは本当に役立ちます。私が特に厳しいのはフロントエンドJSからサーバーサイドJSまでのクロスオーバがどこにあるのか、またサーバーサイドJSを適切な場所で実行しようとしているのかどうかを判断することです。私はこれを行う方法についてオンラインで良いチュートリアルを見つけていないので、なぜ私はここに投稿しています。 React & Node.js
にはかなり新しくて不明な点がある場合は教えてください。上のコードのいくつかは非常に論理的ではないかもしれません。
投稿の表示方法を簡単に教えてください。私が苦労しているのは、フロントエンドをサーバー側にリンクする部分です。他の場所にあるサーバーをホスティングすることについてのあなたの意見は理にかなっています。例えば、良い選択肢であるようなExpressのような、良いフレームワークをお勧めしますか? –
はい、Expressは良い選択です。過去にスタック全体をJavascriptにしたいときは何をしましたか?あなたのフロントエンドコードがどのように見えるか、この答えをチェックしてください:http://stackoverflow.com/questions/28750489/upload-file-component-with-reactjs – Conan
私のapp.jsファイルの上にもう1つ、私が'import'のようなものを使う 'react'から反応する。 - このNode.jsですか? –