ホームページ >ウェブフロントエンド >jsチュートリアル >FormData オブジェクトはファイルをアップロードします
<a href="http://www.php.cn/wiki/125.html" target="_blank"><code><a href="http://www.php.cn/wiki/125.html" target="_blank">For</a>mData
对象,是可以使用一系列的键值对来模拟一个完整的表单,然后使用<a href="http://www.php.cn/wiki/1527.html" target="_blank">XML</a>HttpRequest
发送这个"表单"。
在 Mozilla Developer 网站 使用FormData对象 有详尽的FormData
对象使用说明。
但上传文件部分只有底层的XMLHttpRequest
对象发送上传请求,那么怎么通过<a href="http://www.php.cn/wiki/1495.html" target="_blank">jQuery</a>
的Ajax
上传呢?
本文将介绍通过jQuery
使用FormData
对象上传文件。
<form>
表单初始化FormData
对象方式上传文件HTML代码
<form id="uploadForm" enctype="multipart/form-data"> <input id="file" type="file" name="file"/> <button id="upload" type="button">upload</button> </form>
$.ajax({ url: '/upload', type: 'POST', cache: false, data: new FormData($('#uploadForm')[0]), processData: false, contentType: false }).done(function(res) { }).fail(function(res) {});
这里要注意几点:
processData
设置为false
。因为data
值是FormData
对象,不需要对数据做处理。
<form>
标签添加enctype="multipart/form-data"
属性。
cache
设置为false
,上传文件不需要缓存。
contentType
设置为false
。因为是由<form>
表单构造的FormData
对象,且已经声明了属性enctype="multipart/form-data"
,所以这里设置为false。
上传后,服务器端代码需要使用从查询参数名为file
获取文件输入流对象,因为<input>
中声明的是name="file"
。
如果不是用<form>
表单构造FormData
对象又该怎么做呢?
FormData
对象添加字段方式上传文件HTML代码
<p id="uploadForm"> <input id="file" type="file"/> <button id="upload" type="button">upload</button> </p>
这里没有<form>
标签,也没有enctype="multipart/form-data"
属性。
javascript代码
var formData = new FormData(); formData.append('file', $('#file')[0].files[0]); $.ajax({ url: '/upload', type: 'POST', cache: false, data: formData, processData: false, contentType: false }).done(function(res) { }).fail(function(res) {});
这里有几处不一样:
append()
的第二个参数应是文件对象,即$('#file')[0].files[0]
。
contentType
也要设置为‘false’。
从代码$('#file')[0].files[0]
中可以看到一个<input type="file">
标签能够上传多个文件,
只需要在<input type="file">
里添加multiple
或multiple="multiple"
属性。
从<a href="http://www.php.cn/wiki/1516.html" target="_blank">Servlet</a> 3.0
开始,可以通过 request.getPart()
或 request.getPars()
mData 用://www .php.cn/wiki/60.html" target="_blank">オブジェクト は、一連のキーと値のペアを使用して完全なフォームをシミュレートし、<a href="http://%20www%20.php.cn/wiki/1527.html" target="_blank">XML<br>HttpRequest</a>
この「フォーム」を送信します。
FormData
オブジェクトの使用方法の詳細な手順は、Mozilla Developer Web サイトにあります。 🎜🎜ただし、アップロード 🎜 ファイル部分には、基礎となる XMLHttpRequest
のみが含まれます。 > オブジェクト アップロード リクエストを送信し、<a href="http://www.php.cn/wiki/1495.html" target="_blank">jQuery🎜</a>
を渡す方法 Ajax code> アップロードについてはどうですか? 🎜この記事では、FormData
オブジェクトを使用して、jQuery
経由でファイルをアップロードする方法を紹介します。 🎜<form>
フォームの初期化 FormData
オブジェクト メソッドを使用してファイルをアップロードしますprocessData
は false
に設定されています。 data
値は FormData
オブジェクトであるため、データを処理する必要はありません。 🎜<form>
タグが追加されました enctype="multipart/form-data"
属性🎜。 🎜
cache
は false
に設定されており、ファイルのアップロードには キャッシュ🎜。 🎜
contentType
は false
に設定されています。これは、<form>
フォームから構築された FormData
オブジェクトであり、属性 enctype="multipart/form-data"
が設定されているためです。宣言されているため、This は false に設定されます。 🎜<input>
が name="file"
を宣言しているため、パラメータ名 file
をクエリしてファイル入力ストリーム オブジェクトを取得します。 🎜🎜 <form> フォームを使用して FormData
オブジェクトを構築しない場合はどうすればよいでしょうか? 🎜
FormData
オブジェクトを使用してファイルをアップロードするフィールドを追加します
🎜HTML コード🎜rrreee🎜 <form>
タグや はありませんenctype ="multipart/form-data"
属性。 🎜🎜JavaScript コード🎜rrreee🎜ここにはいくつかの違いがあります: 🎜
- 🎜
append()
の 2 番目のパラメータはファイル オブジェクトである必要があります、つまり $('#file')[0].files[0]
です。 🎜
- 🎜
contentType
も「false」に設定する必要があります。 🎜
🎜 <input type="file" はコード <code>$('#file')[0].files[0]
から確認できます。 >
タグは複数のファイルをアップロードできます。🎜<input type="file">
に multiple
または multiple= を追加するだけです。 「複数」
プロパティ。 🎜<a href="http://www.php.cn/wiki/1516.html" target="_blank">Servlet🎜 3.0 まず、<code>request.getPart()
または request.getPars()
という 2 つの 🎜インターフェース🎜 を通じてアップロードされたファイルを取得できます。 🎜ここで言うことはあまりありません。詳細については、公式 Web サイトのチュートリアル「Java サーブレット テクノロジを使用したファイルのアップロード」とサンプル「fileupload サンプル アプリケーション」を参照してください。
以上がFormData オブジェクトはファイルをアップロードしますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。