AjaxはXML非同期送信による二次連携を実現
今回は、XML 非同期送信による二次連携を実現するための Ajax について説明します。注意事項 について、実際の事例を見てみましょう。
2次連携を実現するためにJavaScriptの配列から州や市の情報を取得することは以前書きましたが、データベースから情報を取得したいというニーズも多いようなので、非同期の考え方で実装する必要があります。ユーザーインタラクションの問題を改善します
最初のメソッドは XML メソッドです
1 まず、JSP ページの JavaScript では、このコードを関数の外に置きます。他の関数で共有できるようにします
var xhr=false; //创建XMLHttpRequst对象 if(window.XMLHttpRequest) { xhr=new XMLHttpRequest(); } else if(window.ActiveXObject) { xhr=new ActiveXObject("Microsoft.XMLHTTP"); } else { xhr=false; }
を使用します2. 選択した州の値を取得し、非同期送信を通じてサーブレットに値を渡します
//获取城市的信息 function getCity() { //省份下拉框的对象 var provinceobj=document.getElementById("province"); //被选择的省份的索引 var index=provinceobj.selectedIndex; //被选择的省份的value值 var provincevalue=provinceobj[index].value; //被选择的省份的text值 var province=provinceobj[index].Text; alert(provincevalue); var url="<%=basepath%>CityServlet";/* post请求不在url上带参数 */ <%-- var url="<%=basepath%>CityServlet?provincevalue="+provincevalue; --%>//get请求在url上带参数 xhr.open("post",url,true);//设置为post提交方式,true表示为异步提交 //post提交方式的时候需要设置提交的编码 xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); //当状态改变时,调用callBack_XML来判断是否需要接收数据 xhr.onreadystatechange=callBack_XML;//xml方法 //通过post提交的时候需要将数据放到send里传到servlet里 xhr.send("provincevalue="+provincevalue); //xhr.send(null); }
3. コールバック関数callBack_XML()を記述します。関数は、サーバーの応答が正常であるかどうかを判断し、データを受信して処理します
function callBack_XML()//xml方法来获取 { //城市下拉选择框的对象 var cityobj=document.getElementById("city"); //当请求状态等于4时,相应已完成,可以访问服务器响应并使用它 if(xhr.readyState==4) { //当状态为200时意味着,状态正常,未出错 if(xhr.status==200) { alert("响应成功"); //获取相应的xml文档 var cityxml=xhr.responseXML; alert(cityxml); //获取根元素 var root=cityxml.documentElement; //获取根元素(city_info)下面的所有city元素 var cities=root.getElementsByTagName("city"); //将下拉框内容清除 cityobj.options.length=1; for(var i=0;i<cities.length;i++) { var city=cities[i]; //获取节点的值 var cid=city.childNodes[0].firstChild.nodeValue; var cname=city.childNodes[2].firstChild.nodeValue; //alert(cid+" "+cname); //放到下拉选择框里Option(文本内容,value值); cityobj.options[cityobj.options.length]=new Option(cname,cid); } } //当状态为404时,表示找不到页面 else if(xhr.status==404) { alert("Request URL is not exists!"); } else { alert("Error:Status is:"+request.status); } } }
4. サーブレット ページで:
String provincevalue=request.getParameter("provincevalue"); System.out.println("省份编号:"+provincevalue); CityService cityservice=CityService.getCityService(); List<City> citylist=cityservice.getCity(provincevalue); for(int i=0;i<citylist.size();i++) { System.out.println(citylist.get(i)); } //生成xml页面 StringBuffer xml=new StringBuffer(); xml.append("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"); xml.append("<city_info>"); for(City c : citylist) { xml.append("<city>"); xml.append("<id>"+c.getId()+"</id>"); xml.append("<cityid>"+c.getCityid()+"</cityid>"); xml.append("<cityname>"+c.getCity()+"</cityname>"); xml.append("<province>"+c.getFather()+"</province>"); xml.append("</city>"); } xml.append("</city_info>"); //设置响应字符集编码,防止中文乱码 response.setCharacterEncoding("utf-8"); response.setContentType("text/xml;charset=utf-8"); //将xml文档写出去 PrintWriter writer=response.getWriter(); //因为只能写字符串,所以toString writer.write(xml.toString()); writer.flush(); writer.close(); }
これで、XML を使用して非同期送信と部分更新を実装し、地方自治体と地方自治体の二次連携を実現します。
この記事の事例を読んだ後、あなたはそれをマスターしたと思います。さらにエキサイティングな方法については、php 中国語 Web サイトの他の関連記事に注目してください。
推奨読書:
以上がAjaxはXML非同期送信による二次連携を実現の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック









Huawei 携帯電話にデュアル WeChat ログインを実装するにはどうすればよいですか?ソーシャルメディアの台頭により、WeChatは人々の日常生活に欠かせないコミュニケーションツールの1つになりました。ただし、多くの人は、同じ携帯電話で同時に複数の WeChat アカウントにログインするという問題に遭遇する可能性があります。 Huawei 社の携帯電話ユーザーにとって、WeChat の二重ログインを実現することは難しくありませんが、この記事では Huawei 社の携帯電話で WeChat の二重ログインを実現する方法を紹介します。まず第一に、ファーウェイの携帯電話に付属するEMUIシステムは、デュアルアプリケーションを開くという非常に便利な機能を提供します。アプリケーションのデュアルオープン機能により、ユーザーは同時に

プログラミング言語 PHP は、さまざまなプログラミング ロジックやアルゴリズムをサポートできる、Web 開発用の強力なツールです。その中でも、フィボナッチ数列の実装は、一般的で古典的なプログラミングの問題です。この記事では、PHP プログラミング言語を使用してフィボナッチ数列を実装する方法を、具体的なコード例を添付して紹介します。フィボナッチ数列は、次のように定義される数学的数列です。数列の最初と 2 番目の要素は 1 で、3 番目の要素以降、各要素の値は前の 2 つの要素の合計に等しくなります。シーケンスの最初のいくつかの要素

Huawei 携帯電話に WeChat クローン機能を実装する方法 ソーシャル ソフトウェアの人気と人々のプライバシーとセキュリティの重視に伴い、WeChat クローン機能は徐々に人々の注目を集めるようになりました。 WeChat クローン機能を使用すると、ユーザーは同じ携帯電話で複数の WeChat アカウントに同時にログインできるため、管理と使用が容易になります。 Huawei携帯電話にWeChatクローン機能を実装するのは難しくなく、次の手順に従うだけです。ステップ 1: 携帯電話システムのバージョンと WeChat のバージョンが要件を満たしていることを確認する まず、Huawei 携帯電話システムのバージョンと WeChat アプリが最新バージョンに更新されていることを確認します。

PHP と Ajax を使用してオートコンプリート候補エンジンを構築します。 サーバー側スクリプト: Ajax リクエストを処理し、候補を返します (autocomplete.php)。クライアント スクリプト: Ajax リクエストを送信し、提案を表示します (autocomplete.js)。実際のケース: HTML ページにスクリプトを組み込み、検索入力要素の識別子を指定します。

今日のソフトウェア開発分野では、効率的で簡潔かつ同時実行性の高いプログラミング言語として、Golang (Go 言語) が開発者にますます好まれています。豊富な標準ライブラリと効率的な同時実行機能により、ゲーム開発の分野で注目を集めています。この記事では、ゲーム開発に Golang を使用する方法を検討し、具体的なコード例を通じてその強力な可能性を示します。 1. ゲーム開発における Golang の利点 Golang は静的型付け言語として、大規模なゲーム システムの構築に使用されます。

PHP ゲーム要件実装ガイド インターネットの普及と発展に伴い、Web ゲーム市場の人気はますます高まっています。多くの開発者は、PHP 言語を使用して独自の Web ゲームを開発することを望んでおり、ゲーム要件の実装は重要なステップです。この記事では、PHP 言語を使用して一般的なゲーム要件を実装する方法を紹介し、具体的なコード例を示します。 1. ゲームキャラクターの作成 Web ゲームにおいて、ゲームキャラクターは非常に重要な要素です。ゲームキャラクターの名前、レベル、経験値などの属性を定義し、これらを操作するメソッドを提供する必要があります。

MySQL トランザクション処理: 自動送信と手動送信の違い。MySQL データベースでは、トランザクションは一連の SQL ステートメントです。すべての実行が成功するか、すべての実行が失敗するかのいずれかで、データの一貫性と整合性が保証されます。 MySQL では、トランザクションは自動送信と手動送信に分けられ、その違いはトランザクション送信のタイミングとトランザクションの制御範囲にあります。以下では、自動送信と手動送信の違いを詳しく紹介し、具体的なコード例を示して説明します。 1. MySQL が表示されない場合は自動的に送信する

jQueryAJAX エラー 403 の問題を解決するにはどうすればよいですか? Web アプリケーションを開発する場合、非同期リクエストを送信するために jQuery がよく使用されます。ただし、jQueryAJAX の使用時に、サーバーによってアクセスが禁止されていることを示すエラー コード 403 が発生する場合があります。これは通常、サーバー側のセキュリティ設定が原因ですが、回避する方法があります。この記事では、jQueryAJAX エラー 403 の問題を解決する方法と具体的なコード例を紹介します。 1.作る
