このサイトは、只今WEB業界で活躍中のデザイナー、プログラマーの方々の情報を集めたweb統合情報サイトです。

Archives Details

JavaScript Ajax XMLHttpRequest

JavaScript

2012.05.19

この記事は最終更新日から1年以上が経過しています。

AjaxはJesseJamesGarrettが発表した用語で、「Asynchronous JavaScript + XML」(非同期的なJavaScript + XML)の略ですが、Ajax とはそもそもなんなのか。

ってところですよね。

一般的に使われているAjaxという言葉はあいまいですが「JavaScriptでサーバーからデータを取り出して活用するページ」がAjaxを使ってページと呼ばれています。

また、Garrettによる定義で「XMLHttpRequestを使った非同期的なデータの取り出し」とあり、XMLHttpRequestでXMLデータを取り出すテクニックが狭い意味でのAjaxと見なされるようです。

XMLHttpRequestオブジェクトの作成

XMLHttpRequestオブジェクトはその名のとおりXMLデータをHTTPプロトコルを使って要求するオブジェクトです。

HTTPプロトコルとはブラウザーがサーバーからファイルを受け取るのに使用されてる通信手段で、XMLHttpRequestオブジェクトを使うと、スクリプトの一部がブラウザーになったかのように、サーバーとやり取りが行えます。

では作成方法を

Mozilla, Opera, Safari,IE 7〜

obj = new XMLHttpRequest();

IE6

obj = new ActiveXObject("Msxml2.XMLHTTP");

IE 5,5.5

obj = new ActiveXObject("Microsoft.XMLHTTP");

で作成出来ます。

このオブジェクトの由来は、2000年にマイクロソフト社がWindowsに導入した「MSXML」の機能です。

Microsoft.XMLHTTPはMSXMLバージョン2の機能でMsxml2.XMLHTTPはMSXMLバージョン3の機能を使っています。

その後、MozillaはXMLHTTPと同様の機能を持つXMLHttpRequestオブジェクトを搭載し、OperaとSafariもMozillaの後追いをする形で同様のオブジェクトに対応しています。

IE7からもこれに対応し、obj = new XMLHttpRequest();でXMLHttpRequestオブジェクトを作成することができます。

ではクロスブラウザを考慮したXMLHttpオブジェクトの作成方法を

JavaScript

function createXMLHttp() {
  var obj = null;
  try{ //Safari,Mozilla, Opera, IE 7〜
    obj = new XMLHttpRequest();</div>
  }
  catch(e) {
    try { //IE6
      obj = new ActiveXObject("Msxml2.XMLHTTP");
    }
  catch(e) {
    try { //IE 5,5.5
      obj = new ActiveXObject("Microsoft.XMLHTTP");
    }
    catch(e){}
  }
}
return obj;
}

Comment

Related Article

JavaScriptで、DOMを放り投げる処理

2024.07.27

2022 VIVA JS World Cup 開幕!! 〜 Vue3で作るサッカーゲーム 〜

2022.12.24

OAuthのフローを可視化できるツールを作ってみました。

2020.05.17

令和の時代に、JavaScriptで Shift-JISファイル作成 全銀データフォーマットに対応する。

2020.03.03

インターネットにて世論調査を行う「世論Web」サービスを始めてみました。

2020.01.31

年末のレトロゲーム熱の際、ファミコンソフト一覧パッケージ作ってました。

2020.01.24

あと10日で「jsdo.it」のサービスが終わってしまう!! ソースダウンロードまだの方は急げぇ〜!

2019.10.21

正規表現 先読み後読み 論理積

2019.07.28

「二段階認証?」という方も 5分で覚える パスワードレス WebAuthnのまとめ

2019.07.07

上級者向け JavaScript 問題集 「javascript-questions」日本語翻訳担当してます。

2019.06.22

CATEGORY LIST

LATEST NEWS

アーキテクチャConference 2024に参加してきました。

イベント

2024.11.28

Mac minicomでシリアル通信を行う

電子工作

2024.11.21

Mac 容量足りない問題は、外付けSSDで快適に解決!おすすめ外付けSSD

mac

2024.10.16

Z80エミュレータ- EMUZ80の組み立て

電子工作

2024.10.13

Mac VSCodeで、SFML C++開発環境を作る。

C++

2024.09.09

Rust-SDL2 examplesをすべて試す

Rust

2024.09.01

JavaScriptで、DOMを放り投げる処理

JavaScript

2024.07.27

Rustで創る MOS 6502 CPU その2

Rust

2024.07.23

Rustで創る MOS 6502 CPU その1

Rust

2024.07.19

汎用 3D mesh/model viewerを求め。と、簡単に、FBXファイルをglTF(glb)に変換ツールを求め。

C++

2024.06.06

M1 Macで、OpenGL GLUTを使ってコンパイルする

C

2024.04.27

Rust - Actix Web mongo ユーザー登録 JWT認証

Rust

2024.03.24

RANKING

Follow

SPONSOR

現在、掲載募集中です。



Links

About Us

WEBデザイナーの、WEBデザイナーによる、WEBデザイナーの為のサイト。「みんなで書こう!」と仲間を募ってみたが、結局書くのは自分だけとなってしまいました。日々のメモを綴っていきます。

Entry Profile

Graphical FrontEnd Engineer
- Daisuke Takayama

MAD CITY 北九州市で生まれ育つ。20代はバンド活動に明け暮れ、ふと「webデザイナーになりたい。」と思い、デジタルハリウッド福岡校入学。卒業後、数々の賞を受賞、web業界をざわつかせる。
現在、主に、ゲーム制作中心に港区六本木界隈で活動中。

FOLLOW US