NodeJS と HTML5 を組み合わせて複数のファイルをドラッグ アンド ドロップしてサーバーにアップロードする方法
複数のファイルのドラッグ アンド ドロップ アップロードを実装する単純な Node プロジェクトは、github からダウンロードできます: https://github.com/Johnharvy/upLoadFiles/。
ダウンロードした zip 形式のパッケージを解凍し、webstom を使用してプロジェクトを実行し、node.exe 実行環境が見つからないというメッセージが表示された場合は、node.exe のインストールを指定してください。位置。ここで使用する Express フレームワークはバージョン 3.21.2 です。
ドラッグ効果がどのように実現されるかを簡単に紹介しましょう。
最初にコードを見てみましょう:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <script src="js/jquery.js"></script> <script src="js/EventUtil.js"></script> <title>uploadFile</title> <style> #a1{width:100px;height:100px;background: #aaaaaa;text-align:center;line-height:100px;color:rgba(81, 49, 202, 0.72); margin:150px auto;} </style> </head> <body> <div id="a1">拖拽到此</div> <div id="out-input"></div> <script> var a1=document.getElementById("a1"); function handleEvent(event){ var info ="", output= document.getElementById("out-input"), files,i,len; EventUtil.preventDefault(event); //阻止事件的默认行为 var formData =new FormData(); if(event.type == "drop"){ files=event.dataTransfer.files; i = 0; len= files.length; while( i< len){ info += files[i].name +"("+ files[i].type + "," +files[i].size +"bytes)<br/>"; formData.append("file"+i,files[i]); i++; } output.innerHTML = info; $.ajax({ type:"post", url:"/uploadFile", data:formData, async: false, cache: false, contentType: false, processData: false, //此处指定对上传数据不做默认的读取字符串的操作 success:function(rs){ console.log(rs); }, error:function(r){ alert("文件上传出错!"); } }); } } EventUtil.addHandler(a1, "dragenter", handleEvent); EventUtil.addHandler(a1, "dragover", handleEvent); EventUtil.addHandler(a1, "drop", handleEvent); </script> </body> </html>
HTMLコンテンツは非常に単純で、1つは許可されたドラッグ範囲を示し、もう1つはアップロードされたファイルのコンテンツを表示するために使用されるdivブロックです。
Js 部分:
ここでは、EventUtil インターフェイス オブジェクトを用意しました。その機能は、各ブラウザーで同じイベントをバインドするための小さなライブラリと考えることもできます。すべてのブラウザに共通のイベント バインディング メソッドを実装するには、EventUtil オブジェクトが使用されます。その実装コードは非常に簡単です。
ブラウザがドラッグの 3 つのイベント条件を検出すると、「dragenter」、「dragover」、「drag」のデフォルトの動作がブロックされ、「drag」条件の場合、カスタム イベントが実行されます。
ファイルをアップロードするため、ここでは FormData のインスタンスが使用されます。ファイルは、append() を通じてオブジェクトに追加され、サーバーにアップロードされた後、キュー順に属性オブジェクトに解析されます。イベントでは、イベントに格納されているファイルを取得するために「event.dataTransfer.files」が使用されます。
ここでもう 1 つ注意すべき点は、ファイル オブジェクトをアップロードするときに jquery の ajax メソッドで processData を false に設定する必要があることです。これは、文字列を読み取るデフォルトの操作が使用されないことを意味します。その理由は、デフォルトでは、data オプションを通じて渡されたデータは、それがオブジェクトである場合 (技術的に言えば、文字列でない限り)、処理され、デフォルトのコンテンツ タイプに一致するクエリ文字列に変換されるためです。 "application/x-www-form" -urlencoded"。 DOM ツリー情報やその他の変換したくない情報を送信する場合は、false に設定する必要があります。
ファイルが正常にアップロードされると、コンソールに「{infor:"success"}」という情報が出力されます。
これでフロントエンド部分は終わりです。Node.js 側のコードを見てみましょう。
ファイル構造は次のとおりです:
まずルーティング - app.js の内容を見てみましょう:
var express = require('express'); var routes = require('./routes'); var user = require('./routes/user'); var http = require('http'); var path = require('path'); var app = express(); // all environments app.set('port', process.env.PORT || 3000); app.set('view engine', 'jade'); app.use(express.favicon()); app.use(express.logger('dev')); app.use(express.json()); app.use(express.urlencoded()); app.use(express.methodOverride()); app.use(app.router); app.use(express.static(path.join(__dirname))); exports.app=app; var uploadAction=require("./Action/fileUpload"); //路由事件监听 uploadAction.uploadTest.uploadFile(); //文件上传监听 // development only if ('development' == app.get('env')) { app.use(express.errorHandler()); } app.get('/users', user.list); http.createServer(app).listen(app.get('port'), function(){ console.log('Express server listening on port ' + app.get('port')); });
最初の app.js とはいくつかの違いがあります。 fileUpload.js で使用できます。これを再利用して、fileUpload.js モジュールを導入し、このインターフェイス オブジェクトを通じてモジュールのすべてのメソッドを保存する UploadTest オブジェクトを取得し、uploadFile メソッドを呼び出します。
それでは、最後に fileUpload.js ファイルを見てみましょう:
var multipart = require('connect-multiparty'); var App=require("../app"); var path = require('path'); var fs=require("fs"); var app=App.app; var uploadTest={}; function uploadFile(){ app.post("/uploadFile", multipart(),function(req,res) { var i=0; while(i != null){ if(req.files["file"+i]) upLoad(i); else{ i= null; res.json({infor:"success"});return;} i++; } //上传队列文件 function upLoad(index){ var filename = req.files["file"+index].originalFilename || path.basename(req.files["file"+index].path); //path接口可以指定文件的路径和文件名称,"\结尾默认为路径,字符串结尾默认为文件名" var targetPath = path.dirname("") + '/public/uploadFiles/' + filename; //fs创建指定路径的文件并将读取到的文件内容写入 fs.createReadStream(req.files["file"+index].path).pipe(fs.createWriteStream(targetPath)); } }); } uploadTest.uploadFile=uploadFile; exports.uploadTest=uploadTest;
nodeJs は常に非常にシンプルかつ強力で、非常に創造的であるため、私は気に入っています。ここには、実際にはほとんどキー コードがないことがわかります。ファイル アップロードを実装する論理プロセスを簡単に紹介します。
• アップロードされたファイルのファイル名を取得します
• ファイルとファイルの保存場所を設定します。 name
•読み取りファイルのコンテンツストリームを取得し、コンテンツストリームに書き込む新しいファイルを作成します
複数のファイルをアップロードするために、いくつかのマッチング操作も行いました。これは非常に直感的で、理解するのは難しくありません。
ファイルが正常にアップロードされると、そのファイルはパブリック ファイルの UploadFiles ファイルの下に表示されます。
このファイルで使用されているモジュールはすべて package.json に記録されており、package.json の同じレベルのディレクトリ アドレスを入力し、コマンド「npm install」を使用してインストールできます。 githubからダウンロードしたプロジェクトファイルを直接実行する場合はインストールする必要はありません。
上記は、複数のファイルをサーバーにドラッグアンドドロップするためにエディターが紹介した実装方法です。ご質問があれば、私にメッセージを残してください。全員にすぐに返信します。また、PHP 中国語 Web サイトをサポートしていただきありがとうございます。
NodeJS と HTML5 を組み合わせて複数のファイルをドラッグ アンド ドロップしてサーバーにアップロードする方法に関するその他の関連記事については、PHP 中国語 Web サイトに注目してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









H5プロジェクトを実行するには、次の手順が必要です。Webサーバー、node.js、開発ツールなどの必要なツールのインストール。開発環境の構築、プロジェクトフォルダーの作成、プロジェクトの初期化、コードの書き込み。開発サーバーを起動し、コマンドラインを使用してコマンドを実行します。ブラウザでプロジェクトをプレビューし、開発サーバーURLを入力します。プロジェクトの公開、コードの最適化、プロジェクトの展開、Webサーバーの構成のセットアップ。

H5ページの制作とは、HTML5、CSS3、JavaScriptなどのテクノロジーを使用したクロスプラットフォーム互換のWebページの作成を指します。そのコアは、ブラウザの解析コード、レンダリング構造、スタイル、インタラクティブ機能にあります。一般的なテクノロジーには、アニメーションエフェクト、レスポンシブデザイン、およびデータ相互作用が含まれます。エラーを回避するには、開発者をデバッグする必要があります。パフォーマンスの最適化とベストプラクティスには、画像形式の最適化、リクエスト削減、コード仕様などが含まれ、読み込み速度とコード品質を向上させます。

H5クリックアイコンを作成する手順には、次のものがあります。画像編集ソフトウェアで正方形のソース画像の準備が含まれます。 H5エディターにインタラクティブ性を追加し、クリックイベントを設定します。アイコン全体をカバーするホットスポットを作成します。ページにジャンプしたり、アニメーションのトリガーなど、クリックイベントのアクションを設定します。 HTML、CSS、およびJavaScriptファイルとしてH5ドキュメントをエクスポートします。エクスポートされたファイルをウェブサイトまたは他のプラットフォームに展開します。

H5はスタンドアロンプログラミング言語ではなく、最新のWebアプリケーションを構築するためのHTML5、CSS3、およびJavaScriptのコレクションです。 1。HTML5は、Webページの構造とコンテンツを定義し、新しいタグとAPIを提供します。 2。CSS3はスタイルとレイアウトを制御し、アニメーションなどの新しい機能を紹介します。 3. JavaScriptは動的な相互作用を実装し、DOM操作と非同期要求を通じて機能を強化します。

H5(HTML5)は、マーケティングキャンペーンページ、製品ディスプレイページ、企業プロモーションマイクロウェブサイトなどの軽量アプリケーションに適しています。その利点は、クロスプラットフォームと豊富な対話性にありますが、その制限は複雑な相互作用とアニメーション、ローカルリソースアクセス、オフライン機能にあります。

H5ポップアップウィンドウの作成手順:1。トリガー方法(クリック、時間、終了、スクロール)を決定します。 2。設計コンテンツ(タイトル、テキスト、アクションボタン); 3。SETスタイル(サイズ、色、フォント、背景); 4.コードを実装する(HTML、CSS、JavaScript); 5。テストと展開。

はい、H5ページの生産は、HTML、CSS、JavaScriptなどのコアテクノロジーを含むフロントエンド開発のための重要な実装方法です。開発者は、&lt; canvas&gt;の使用など、これらのテクノロジーを巧みに組み合わせることにより、動的で強力なH5ページを構築します。グラフィックを描画するタグまたはJavaScriptを使用して相互作用の動作を制御します。

H5ReferStoHtml5、apivotaltechnologyinwebdevelopment.1)html5introduceSnewelementsandapisforrich、dynamicwebapplications.2)Itupp ortsmultimediawithoutplugins、endancingurexperiencecrossdevices.3)semanticelementsimprovecontentstructurendseo.4)H5'srespo
