この記事では、主に js 呼び出し json メソッドの概要を詳細に分析します。必要な友人がそれを参照し、学ぶことができると幸いです。
Ajaxの基本
ajax: リフレッシュデータの読み取りなし、サーバー上の情報の読み取り
HTTPリクエストメソッド:
GET: 投稿の閲覧などのデータの取得に使用されます
ajax.judgeXmlHttpRequest('get', 'index.php', function(data){ alert(data); //这是服务器返回的数据 })
POST: ユーザー登録などのデータのアップロードに使用されます
var dataJson = { name: 'ys',age: 123 } ajax.judgeXmlHttpRequest('post', 'index.php', function(data){ alert(data); //这是服务器返回的数据 },dataJson)
GETとPOSTの違い:
GET: URLを介して渡されます(URLを入力します)。渡されたデータはURL、name=value&name=value
getメソッドは容量が小さく、セキュリティが低く、キャッシュがあります
POST: URLを経由しません
postは容量が大きく、通常最大2G、セキュリティは比較的高く、キャッシュはありません
ネイティブ Ajax の作成
Ajax 実行手順
Ajax オブジェクトの作成
IE6 以外のブラウザ:
var oAjax=new XMLHttpRequest();
IE6 ブラウザ:
var oAjax=new ActiveXObject("Microsoft.XMLHTTP");
サーバーに接続
Ajax.open(方法,文件名,异步传输);
キャッシュを防ぐ方法:
Ajax.open('GET','a.txt?t='+new Date().getTime(),true);
同期: js 中指は物事を 1 つずつ実行する必要があることを意味します
非同期: js 中指は複数のことを一緒に実行する必要があることを意味します
ajax は非同期送信用です。非同期
リクエストを送信
Ajax.send();
戻り値を受け取る
リクエストステータス監視: onreadystatechange イベント: Ajax とサーバー間で通信がある場合にトリガーされます。主に、readyState 属性によって判断されます。成功したかどうかはステータス属性によって判断されます
readyState 属性: リクエストステータス
0 (初期化されていません) open メソッドはまだ呼び出されていません
1 (ロード中) send()メソッドが呼び出され、リクエストが送信中です
2 (ロード完了) send()メソッドが完了し、対応するコンテンツをすべて受信しています
3 (解析中) 受信した応答コンテンツを解析中です
4 (完了) 応答内容の解析が完了し、クライアントで呼び出すことができます (完了は必ずしも成功を意味するわけではありません。成功または失敗を検出するにはステータスが必要です)
ステータス属性:
リクエスト結果、成功かどうか (200 ) または失敗 (404): Ajax.status==200
戻り値 responseText:
サーバーから返されたテキスト: Ajax .responseText (戻り値は文字列であり、場合によっては他の形式にさらに処理する必要がある)
oAjax.onreadystatechange=function(){ //oAjax.readyState: 表示浏览器和服务器之间进行到哪一步了 if(oAjax.readyState==4){ //读取完成 if(oAjax.status==200){ //读取的结果是成功 alert('成功:'+oAjax.responseText); } } }
ネイティブ Ajax を関数にカプセル化します。最終的に記述されたネイティブ Ajax は次のとおりです。
GET メソッドのカプセル化 POST メソッドによってカプセル化された関数は次のとおりです。
function ajax(url,fnSuccess,fnFaild){ //1.创建Ajax对象。js中,使用一个没有定义的变量会报错,使用一个没有定义的属性,是undefined。IE6下使用没有定义的XMLHttpRequest会报错,所以当做window的一个属性使用 if (window.XMLHttpRequest) { var oAjax=new XMLHttpRequest();//非IE6 }else{ var oAjax=new ActiveXObject("Microsoft.XMLHTTP");//IE6 } //2.连接到服务器 oAjax.open('GET',url,true); //3.发送请求 oAjax.send(); //4.接收返回值 oAjax.onreadystatechange=function(){ //oAjax.readyState--浏览器和服务器之间进行到哪一步了 if(oAjax.readyState==4){ //读取完成 if(oAjax.status==200){ //读取的结果是成功 fnSuccess(oAjax.responseText); //成功时执行的函数 }else{ if(fnFaild){ //判断是否传入失败是的函数,即用户是否关心失败时的结果 fnFaild(oAjax.responseText); //对失败的原因做出处理 } } } } }
POST によってカプセル化された関数メソッドは:
function ajaxPost(url,id,fnSuccess,fnFaild){ //1.创建Ajax对象 if (window.XMLHttpRequest) { var xhr=new XMLHttpRequest();//非IE6 }else{ var xhr=new ActiveXObject("Microsoft.XMLHTTP");//IE6 } //2.连接到服务器 xhr.open("POST",url,true); //设置头信息 xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); var form=document.getElementById(id); //3.发送请求,传递数据 xhr.send(serialize(form)); xhr.onreadystatechange=function(){ if(xhr.readyState==4){ if ((xhr.status>=200 && xhr.status<300) || xhr.status==304) { fnSuccess(xhr.responseText); }else{ fnFaild(xhr.responseText); } } }; }
文字セットエンコーディング: Web ページと要求されたファイルのエンコーディングは、両方が utf8 の場合は同じである必要があります
キャッシュ、ブロックキャッシュ (頻繁に変更されるデータなどはキャッシュできません。主に GET メソッドに使用されます)。パラメータを渡すときに、パスの後に ?+'variable data' を追加すると、元のデータに影響を与えることなく動的データをリクエストできます
ajax('a.txt?t='+new Date().getTime(),function(str){ alert(str); },function(str){ alert(str); });
ajax : json ファイルなど
1 value は文字列であり、返された配列/json データは eval 変換を通じて読み取ることができます
alert(str); alert(typeof(str)); var arr=eval(str); alert(typeof(arr)); alert(arr[1]); alert(arr[1].c);
2 DOM と組み合わせて、返されたコンテンツを表示する要素を作成します
oBtn.onclick=function(){ ajax('data/arr3.txt?t='+new Date().getTime(),function(str){ var arr=eval(str); for (var i = 0; i < arr.length; i++) { var oLi=document.createElement('li'); oLi.innerHTML='用户名:<span>'+arr[i].user+'</span>密码:<span>'+arr[i].pass+'</span>'; oUl.appendChild(oLi); } },function(str){ alert(str); }); }
データ型-->返されるデータ型は、xml (ほぼ削除されています)、json (現在は一般的に使用されています) です
最近、get メソッドを通じて json を呼び出すネイティブ js を作成した例を見てみましょう:
if(!isNaN(matchId)) { var xmlHttp = null; try {// Chrome, Firefox, Opera, Safari xmlHttp = new XMLHttpRequest(); }catch (e) { try {// Internet Explorer IE 6.0+ xmlHttp = new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try {// Internet Explorer IE 5.5+ xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e) { alert("your browser not support ajax!"); } } } window.onload = function () { xmlHttp.open("get",/api/clientMatch/commonMatchDiagram.json?matchId=" + matchId,true); xmlHttp.send(); xmlHttp.onreadystatechange = doResult; //设置回调函数 }; function doResult() { var html=''; if ((xmlHttp.readyState == 4)&&(xmlHttp.status == 200)) {//4代表执行完成,200代表执行成功 var data = JSON.parse(xmlHttp.responseText); if(data.code == 200){ //代码执行 } document.getElementById('appMatch').innerHTML = html; } } }
関連する推奨事項:
PHP のクロスドメインで json_jquery を呼び出す例
PHP5.5 インストール後、json_encode を呼び出すことができません。
以上がjsからjsonを呼び出す方法まとめの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。