ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScriptは受信用のバックグラウンドへのファイルのアップロードを実装します

JavaScriptは受信用のバックグラウンドへのファイルのアップロードを実装します

小云云
小云云オリジナル
2018-05-19 13:36:295005ブラウズ

WordPress バックグラウンド管理のプラグイン管理インターフェイスで、更新せずに Ajax アップロードを追加したいです まずアイデアについて話させてください: ファイルをアップロードするには、現在のファイルのデータ ストリームを取得する必要があります。そして、 ajax post を通じて処理するためにサーバーに送信します。

(1) 現在のファイルのデータストリームを取得するには?

回答: FormData() によってインスタンス化されたオブジェクトを通じて変数にファイル データを追加します

(2) データを取得するにはどうすればよいですか?

回答: file タイプの入力フォームには、files 属性が付属します。

HTML ページがファイル アップロード リクエストを送信します:

	<input type="file" name="upload_img" id=&#39;upload_img&#39;/>
	<img src="" id=&#39;myfile_img&#39; alt=&#39;&#39; title=&#39;&#39; width=&#39;300&#39;/> 
	<script type="text/javascript">
	
	var uploadImg = document.getElementById(&#39;upload_img&#39;);
	var myfileImg = document.getElementById(&#39;myfile_img&#39;);

	uploadImg.onchange = function()
	{
		var imgName = this.files[0].name;
		//let reader = new FileReader();
		var fordata = new FormData();
		fordata.append(&#39;my_file&#39;,this.files[0]);
		
		//向服务器发送文件数据
		ajaxPost(fordata,function(obj){

			var content = JSON.parse(obj.response);
			console.log(content);
			if(content.status == &#39;sucess&#39;){
				myfileImg.src = &#39;./images/&#39;+imgName;
			}
		});

	}

	function ajaxPost(data,fn)
	{
		var xhr = new XMLHttpRequest();
		xhr.open(&#39;post&#39;,&#39;./upload.php&#39;,&#39;true&#39;);
		xhr.send(data);
		xhr.onload = function()
		{
			fn(this);
		} 
	}
	</script>

サーバーはファイル データを処理し、アップロードされたファイルを生成します:

$success = array(&#39;status&#39; => &#39;sucess&#39;, &#39;code&#39; => &#39;1&#39;);
$error = array(&#39;status&#39; => &#39;error&#39;, &#39;code&#39; => &#39;0&#39;);

if (!empty($_FILES)) {
    $file = $_FILES[&#39;my_file&#39;];

    $new_file_dir = dirname(__FILE__) . &#39;/images/&#39; . $file[&#39;name&#39;];
    @move_uploaded_file($file[&#39;tmp_name&#39;], $new_file_dir);

    exit(json_encode($success));
} else {
    exit(json_encode($error));
}

関連する推奨事項:

更新せずにアップロードされたファイルを実装する JavaScript メソッドの紹介

以上がJavaScriptは受信用のバックグラウンドへのファイルのアップロードを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。