ホームページ  >  記事  >  ウェブフロントエンド  >  AJAXとJavaScriptの使い方を詳しく解説

AJAXとJavaScriptの使い方を詳しく解説

php中世界最好的语言
php中世界最好的语言オリジナル
2018-03-31 13:39:331497ブラウズ

今回は、AJAX と JavaScript の使用について詳しく説明します。AJAX と JavaScript を使用する際の 注意事項 は何ですか?実際の事例を見てみましょう。

AJAX は JavaScript 仕様ではなく、仲間によって「発明された」単なる略語です: Asynchronous JavaScript and XML、つまり JavaScript を使用して非同期ネットワーク リクエストを実行することを意味します。

フォームの送信を注意深く観察すると、ユーザーが「送信」ボタンをクリックしてフォームの送信が開始されると、ブラウザーがページを更新し、新しいページで操作が完了したかどうかを通知することがわかります。成功したか失敗したか。残念ながらネットワークが遅すぎる場合、またはその他の理由により、404 ページが表示されます。

これが Web の仕組みです。1 つの HTTP リクエストが 1 つのページに対応します。

ユーザーが現在のページに留まり、同時に新しい HTTP リクエストを行うようにするには、データを受信した後、JavaScript を使用してページを更新する必要があります。ユーザーはまだ現在のページに留まっているように感じますが、データは継続的に更新されます。

AJAX が最初に大規模に使用されたのは Gmail で、Gmail ページが初めてロードされた後、残りのデータはすべて AJAX に依存して更新されました。

JavaScript で完全な AJAX コードを記述することは複雑ではありませんが、注意する必要があります。AJAX リクエストは非同期で実行されます。つまり、応答は

コールバック関数 を通じて取得されます。 最新のブラウザでの AJAX の記述は、主に
XMLHttpRequestオブジェクトに依存します:

function success(text) {
 var textarea = document.getElementById('test-response-text');
 textarea.value = text;
}
function fail(code) {
 var textarea = document.getElementById('test-response-text');
 textarea.value = 'Error code: ' + code;
}
var request = new XMLHttpRequest(); // 新建XMLHttpRequest对象
request.onreadystatechange = function () { // 状态发生变化时,函数被回调
 if (request.readyState === 4) { // 成功完成
  // 判断响应结果:
  if (request.status === 200) {
   // 成功,通过responseText拿到响应的文本:
   return success(request.responseText);
  } else {
   // 失败,根据响应码判断失败原因:
   return fail(request.status);
  }
 } else {
  // HTTP请求还在继续...
 }
}
// 发送请求:
request.open('GET', '/api/categories');
request.send();
alert('请求已发送,请等待响应...');
IE の以前のバージョンでは、ActiveX

Object オブジェクトに変更する必要があります:

function success(text) {
 var textarea = document.getElementById('test-ie-response-text');
 textarea.value = text;
}
function fail(code) {
 var textarea = document.getElementById('test-ie-response-text');
 textarea.value = 'Error code: ' + code;
}
var request = new ActiveXObject('Microsoft.XMLHTTP'); // 新建Microsoft.XMLHTTP对象
request.onreadystatechange = function () { // 状态发生变化时,函数被回调
 if (request.readyState === 4) { // 成功完成
  // 判断响应结果:
  if (request.status === 200) {
   // 成功,通过responseText拿到响应的文本:
   return success(request.responseText);
  } else {
   // 失败,根据响应码判断失败原因:
   return fail(request.status);
  }
 } else {
  // HTTP请求还在继续...
 }
}
// 发送请求:
request.open('GET', '/api/categories');
request.send();
alert('请求已发送,请等待响应...');
標準の記述と IE の記述を混合したい場合, 次のように記述できます:

var request;
if (window.XMLHttpRequest) {
 request = new XMLHttpRequest();
} else {
 request = new ActiveXObject('Microsoft.XMLHTTP');
}

windowオブジェクトにXMLHttpRequest属性があるかどうかを検出することで、ブラウザが標準のXMLHttpRequestをサポートしているかどうかを判断します。ブラウザーが特定の JavaScript 機能をサポートしているかどうかを検出するためにブラウザーの navigator.userAgent を使用しないでください。第一に、文字列自体が偽造される可能性があり、第二に、JavaScript 機能を介して判断するのは非常に複雑になるためです。 IEのバージョン。

XMLHttpRequestオブジェクトを作成した後、まずonreadystatechangeのコールバック関数を設定する必要があります。コールバック関数では通常、readyState === 4によってリクエストが完了したかどうかを判断するだけで済み、完了した場合はstatus === 200に基づいて成功応答かどうかを判断します。
XMLHttpRequest オブジェクトの open() メソッドには 3 つのパラメーターがあり、最初のパラメーターは GET か POST かを指定し、2 番目のパラメーターは URL アドレスを指定し、3 番目のパラメーターは非同期を使用するかどうかを指定します。デフォルトはtru​​eなので書く必要はありません。

、3 番目のパラメータを false として指定しないでください。そうしないと、AJAX リクエストが完了するまでブラウザが応答を停止します。このリクエストに 10 秒かかる場合、10 秒以内にブラウザが「サスペンドデス」状態になっていることがわかります。

最後にsend()メソッドを呼び出して実際にリクエストを送信します。 GET リクエストにはパラメーターは必要ありませんが、

POST リクエストには本文部分を文字列または FormData オブジェクトとして渡す必要があります。

セキュリティ制限

上記のコードの URL は相対パスを使用しています。 「http://www.sina.com.cn/」に変更して再度実行すると、必ずエラーが報告されます。 Chrome コンソールでは、

エラー メッセージも表示されます。 これはブラウザの同一生成元ポリシーが原因で発生します。デフォルトでは、JavaScript が AJAX リクエストを送信するとき、URL のドメイン名は現在のページとまったく同じである必要があります。

完全一致的意思是,域名要相同(www.example.comexample.com不同),协议要相同(http和https不同),端口号要相同(默认是:80端口,它和:8080就不同)。有的浏览器口子松一点,允许端口不同,大多数浏览器都会严格遵守这个限制。

那是不是用JavaScript无法请求外域(就是其他网站)的URL了呢?方法还是有的,大概有这么几种:

一是通过Flash插件发送HTTP请求,这种方式可以绕过浏览器的安全限制,但必须安装Flash,并且跟Flash交互。不过Flash用起来麻烦,而且现在用得也越来越少了。

二是通过在同源域名下架设一个代理服务器来转发,JavaScript负责把请求发送到代理服务器:
'/proxy?url=http://www.sina.com.cn'代理服务器再把结果返回,这样就遵守了浏览器的同源策略。这种方式麻烦之处在于需要服务器端额外做开发。

第三种方式称为JSONP,它有个限制,只能用GET请求,并且要求返回JavaScript。这种方式跨域实际上是利用了浏览器允许跨域引用JavaScript资源:

<html>
<head>
 <script src="http://example.com/abc.js"></script>
 ...
</head>
<body>
...
</body>
</html>

JSONP通常以函数调用的形式返回,例如,返回JavaScript内容如下:
foo('data');这样一来,我们如果在页面中先准备好foo()函数,然后给页面动态加一个