ホームページ >ウェブフロントエンド >H5 チュートリアル >画像アップロード プラグイン ImgUploadJS: HTML5 ファイル API を使用して、スクリーンショットの貼り付けアップロードとドラッグ アンド ドロップでアップロードを実装する _html5 チュートリアル スキル

画像アップロード プラグイン ImgUploadJS: HTML5 ファイル API を使用して、スクリーンショットの貼り付けアップロードとドラッグ アンド ドロップでアップロードを実装する _html5 チュートリアル スキル

WBOY
WBOYオリジナル
2016-05-16 15:46:083588ブラウズ
1. 背景と効果

現在、インターネット上にアップロードされるファイルのほとんどは画像ファイルですが、従来の Web 画像のスクリーンショットをアップロードするには、次の手順が必要です。 スクリーンショットを保存 -> パスを選択 -> ; 保存してから、「アップロード」>「パスの選択」>「アップロード」>「挿入」をクリックします。
画像ファイルのアップロードには、パスを選択してから ->アップロード ->挿入する必要があります。手順は複雑ですが、スクリーンショットの貼り付けアップロードとドラッグ アンド ドロップによるアップロードがサポートされている場合は、インターネット エクスペリエンスが重要です。大きく改善されるでしょう。
現在、Zhihu と Github は両方とも最新のブラウザー向けにこれら 2 つの機能をサポートしています。私は何もすることがなかったときにこれらの機能を実装することを学びました。今日は、この 1kb プラグインがどのような機能を実装しているのか、その使用方法とその原理について説明します。 。
まず挿入エフェクトを見てみましょう:
スクリーンショットを撮ったら、それを直接貼り付けてアップロードします。

ドラッグアンドドロップしてアップロード

http ネットワーク


2. 使用例
直接呼び出し:
XML/HTML コードコンテンツをクリップボードにコピー
  1. <div id="box" スタイル="幅: 800px; 高さ: 400px; ボーダー: 1px ソリッド;" contenteditable="true">div>
  2. <スクリプト type="text/ javascript" src="UploadImage.js">スクリプト>
  3. new UploadImage("box", "UploadHandler.ashx").upload(function (xhr) {//アップロード完了後のコールバック
  4. var img = new Image();
  5. img.src = xhr.responseText; this.appendChild(img);
  6. });
AMD/CMD


XML/HTML コードコンテンツをクリップボードにコピー

  1. <div id="box" スタイル="width: 800px; height: 400px; border: 1px solid;" contenteditable="true">div>
  2. <スクリプト type="text/ javascript" src="require.js">スクリプト>
  3. <スクリプト>
  4. require(['UploadImage'], function (UploadImage) {
  5. new UploadImage("box", "UploadHandler.ashx").upload(function (xhr) {//上传完了後の回调
  6. var img = new Image();    
  7. img.src = xhr.responseText;    
  8. this.appendChild(img);    
  9. });    
  10. })
  11. スクリプト>


三.浏览器サポート
現在のバージョンのみ以下、浏览器、今後さらに多くの浏览器をサポートする可能性があります。
•IE11
•Chrome
•FireFox
•Safari(未测式,理论应该サポート)
四.原理および源码
1.粘贴上传
处理目标容器(id)の貼り付けイベントは、e.clipboardData 内のデータを取得します。図の場合は、次の処理が実行されます。
を使用して H5 File API(FileReader) でファイルの Base64 コードを取得し、FormData 上に送信します。
2.
は対象コンテナ(id)のドロップ イベントを処理し、図の場合は e.dataTransfer.files(H5 ファイル API: FileList)内のデータを取得し、FormData を構築します。
以下は初版の本コードです。これ以上は説明しません。
部核心コード

XML/HTML コード复制コンテンツ到剪贴板
  1. 関数 UploadImage(id, url, key)
  2. {
  3. this.element = ドキュメント.getElementById(id);
  4. this.url = url; //バックエンド画像処理のパス
  5. this.imgKey = key || "PasteAreaImgKey"; // バックエンドに指定された名前
  6. }
  7. UploadImage.prototype.paste = 関数 (コールバック、formData)
  8. {
  9. var
  10. あれ = これ; this.element.addEventListener('paste', function (e) {//ターゲット コンテナ (id) の貼り付けイベントを処理します
  11. if (e.clipboardData && e.clipboardData.items[0].type.indexOf('image')
  12. >
  13. -1) { var
  14. あれ
  15. = これ,
  16. リーダー
  17. = new FileReader(); file
  18. = e.clipboardData.items[0].getAsFile();//e.clipboardData のデータを読み取ります: Blob オブジェクト
  19. reader.onload
  20. =
  21. function (e) { //リーダーの読み取りが完了した後、xhr がアップロードされます var xhr
  22. =
  23. new XMLHttpRequest(), fd
  24. =
  25. formData || (新しい FormData());; xhr.open('POST', thatthat.url, true); xhr.onload
  26. =
  27. 関数
  28. () {
  29. callback.call(that, xhr) }
  30. fd.append(thatthat.imgKey, this.result); // this.result は画像の Base64 を取得します
  31. xhr.send(fd);
  32. }
  33. reader.readAsDataURL(file);//base64 エンコードを取得
  34. }
  35. }、偽);
  36. }
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。