サーバーから返されたデータに基づいて js 処理を実装する Ajax アップロード メソッド

亚连
リリース: 2018-05-25 10:31:28
オリジナル
1423 人が閲覧しました

この記事では、サーバーから返されたデータに基づいて js 処理を実装する Ajax アップロードの方法を主に紹介し、Ajax リクエストと Java 処理およびサーバー側のデータ リクエストを返す関連スキルを分析します。この記事では、サーバー側に基づいて JS 処理用のデータを返すメソッドの Ajax アップロードの実装について説明します。皆さんの参考に共有してください。詳細は次のとおりです。

Ajax アップロードでは、フォーム送信を使用し、現在のページに iframe を追加し、送信されたコンテンツを iframe にジャンプする必要があることが明確に記載されており、ページが更新されていないように見せかけます。

基本的に commons-fileupload コンポーネントを使用してアップロードを行ったことがあります。基本的な手順は、サーブレットを使用してアップロードを処理し、PrintWrite オブジェクト インスタンスを使用して表示コンテンツを直接出力するか、スクリプトを出力することです。

response.getWriter().write("<script type=\"text/javascript\"> parent.item_update.uploadUponSize();</script>");
ログイン後にコピー

response.getWriter().write("上传成功!");
ログイン後にコピー

など。このアプローチでは、すべてのページ側の操作をサーブレットにカプセル化します。アップロードが成功した後、サーバーはサーバー側のサーブレットにアクセスできないことです。識別子を選択し、ページ上で操作を実行します。

フォームがこの iframe に送信されるときにロード イベントをトリガーできるため、この要件の考え方は次のとおりです。


1. フォームが送信されるときに、iframe のロード イベントを登録します。

2. 次に、js を使用して返されたフラグビットを判断します。

3. 複数のバインディング イベントを回避するには、バインディング イベントを削除します。

一例を以下に掲載します。

サーバー側ではより簡単で、返されるフラグは 1 つだけです。

package com.justsy.servlet; 
import java.io.IOException; 
import java.io.PrintWriter; 
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 
public class UploadServlet extends HttpServlet { 
  private static final long serialVersionUID = 1L; 
  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
    this.doPost(request, response) ; 
  } 
  protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
    PrintWriter writer = response.getWriter() ; 
    response.setContentType("text/html") ; 
    writer.print("<root>ok</root>") ; 
  } 
}
ログイン後にコピー

js file

function submitForm(){ 
  $("#hidden_iframe").load(function(){ 
    var content = document.getElementById("hidden_iframe").contentWindow.document.body.innerHTML; 
    content = createXml(content); 
    var root = $(content).find("root").eq(0); 
    alert(root.text()); 
    $("#hidden_iframe").unbind("load"); 
  }); 
  document.getElementById("form2").submit(); 
} 
function createXml(str){ 
  if (document.all) { 
    var xmlDom = new ActiveXObject("Microsoft.XMLDOM"); 
    xmlDom.loadXML(str); 
    return xmlDom; 
  } 
  else { 
    return new DOMParser().parseFromString(str, "text/xml"); 
  } 
}
ログイン後にコピー

html file

<form action="uploadServlet.do" id="form2" enctype="multipart/form-data" method="post" target="hidden_iframe">
  <input type="hidden" name="method" value="uploadExcel" /><input type="button" value="Submit" onclick="submitForm()"/>
</form>
<iframe name="hidden_iframe" id="hidden_iframe" width="300" height="200">
</iframe>
ログイン後にコピー

上記は私がまとめたもので、将来皆さんのお役に立てれば幸いです。

関連記事:

DjangoがAjaxポストデータを使用する場合の403エラーを解決する方法


Ajaxリクエスト結果に対するIEのキャッシュ問題の簡単な分析


さまざまなAJAXの使用方法の詳細な説明メソッド


以上がサーバーから返されたデータに基づいて js 処理を実装する Ajax アップロード メソッドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!