【2/17】今年は「濃厚」技術トーク!@ITメールセミナー スラッシュドット    はてなブックマーク  Yahoo!ブックマークに登録  印刷

第18回 Ajaxの高度な使用例、Yahoo! pipes

株式会社ピーデー
川俣 晶

2007/2/27

Yahoo! pipesをはじめ、JavaScriptで書かれた全文検索エンジン、入力フィールドへの入力をリアルタイムでチェックできるAjaxライブラリを紹介する(編集部)

 ハイライト1・シンプルな操作性のツール、Yahoo! pipes

- PR -

 話題のサービスです。検索エンジンやRSSフィードなど、さまざまなソースのデータを足し合わせ、フィルタリングし、望みの情報だけを抽出したフィードを作り出すことができます。シンプルな分かりやすさと操作性の良さが特徴です。

 Yahoo! pipesは、サーバ側で実行されRSSフィードを出力するサービスで、Ajaxとは直接関係がありません。にもかかわらず、今回のトップで紹介した理由は、パイプのデザインツールが非常によくできているからです。

優れたデザインのパイプで気になることを整理してみよう

 画面左側のパレットから、必要な機能を選んで配置します。場所は自由にドラッグして決めることができます。そして、パーツ間を線でつなぐと、自動的に滑らかな線で結び付けられます。パーツの場所を移動しても線は追従します。さらに、個々のパーツ内部は入力フィールドになっていて、編集できます。これはAjaxの高度な使用例として見る価値があるでしょう。

 ちなみに、これだけ優れたデザイナーがあっても使うのは難しい、面倒くさいという意見もあるでしょう。そういう場合は検索機能を使って、ほかの誰かが作ったパイプを探します。例えば、Ajaxというキーワードで検索すると、いくつものパイプがすでにあることが分かります。

 ハイライト2・企業向け本格Ajaxアプリ、Feedpath Zebra

 この連載の第1回(Webアプリのユーザビリティを改善しまくるAjax)に紹介したZimbraが、Feedpath Zebraという名で日本語サービスを開始しました。これは、メッセージングとコラボレーションの機能を持つ企業向けの本格Ajaxアプリケーションです。

Ajaxでメール機能を提供している

 すぐにデモを体験できます。上記のFeedpath Zebraのサイトに飛び、「デモ」のリンクをクリックしてみましょう。能書きを並べるよりも雄弁に、使い勝手を納得できると思います。

 ハイライト3・Microsoft ASP.NET AJAX正式リリース

 マイクロソフトのAjaxライブラリの正式版がリリースされました。旧称Atlas、正式名をASP.NET AJAXと呼びます。

 といっても、これは単純な存在ではありません。このライブラリは3つの切り口から見ることができます。

 第一に、これまでのASP.NETによるサーバ側プログラミングを強化するライブラリとしての位置付けです。ASP.NETはサーバ側で実行されるため、何かあればリクエストをサーバに送信してページ全体を更新していました。

 しかし、ASP.NET AJAXを使うと部分更新ができるようになり、効率や使い勝手が上がります。しかも、プログラマはJavaScriptのことを何も知らずともASP.NET AJAXがうまくやってくれます。

 第2に、JavaScriptプログラマの立場からはマイクロソフトが提供する便利なJavaScriptライブラリという位置付けを持ちます。JavaScriptにはすでに多数のライブラリがありますが、ASP.NET AJAXの存在意義はマイクロソフトの技術との親和性にあると感じます。

 例えば、文字列を累積して高速に結合するオブジェクトはStringBuilderと呼ばれますが、これは.NET Frameworkの同様の機能を持つクラスと同名です。それ故に、C#などのプログラマには覚えやすいネーミングだといえます。

 最後は、PHPに対する目配りです。ASP.NET AJAXは、マイクロソフトの技術だけで閉じてはおらず、PHPと併用されることも意識しているようです。もちろん、PHPと併用した場合の使い勝手は、マイクロソフト製品と併用した場合と比べて落ちることもあるでしょうが、PHPが拒絶されているわけではないのです。

 以上のようなASP.NET AJAXの持つ多面性が、もはや善悪二元論で切り分けられるほど世の中は単純ではない……という時代にどのように意味を持つのか、この先が興味深いですね。

 そのほかのみどころ

 Ajaxとそれに関連する話題を紹介します。

JavaScriptで書かれた全文検索エンジン

 JavaScriptで全文検索エンジンを書いたという強者が現れました。これはいうほど楽な話ではありません。なぜかといえば、膨大な量の文書を素早く検索するには、単純な文字列処理では済まないからです。

 大きなインデックスを作り、データを効率の良い形に置き換えて処理しなければなりません。文字列を検索するという目的を達成するために、バイナリーデータも扱わねばならないのです。しかし、JavaScriptはストレートにバイナリーデータを扱うことができません。そのあたりの苦労話も、上記のページには書かれています。

CDやDVDなどの検索APIが公開

 あの楽天が、Webサービスのベータ版の提供を開始しました。楽天が扱う商品、CDやDVDなどの検索APIなどが公開されています。楽天が扱う商品の範囲の大きさを考えれば、アイデア次第で魅力的なサービスをマッシュアップできる可能性があります。

Snipshot (Ajaxによる画像編集)

 Ajaxによる画像編集サービスです。自分のサイトにも取り込めます。

URLを入力してWeb上の画像を編集することもできる

 実際に使ってみると分かりますが、Ajaxによって十分に実用的なユーザーインターフェイスが提供されていて、トリミング、リサイズ、色の調整などができます。

入力フィールドへの入力をリアルタイムでチェック

 入力フィールドに正しい条件を満たす値が入力されているかをリアルタイムでチェックし、誤っていた場合にヒントを表示するライブラリです。このような機能はサイトの利用者に対して分かりやすく親切なので、できるだけ付けるといいと思います。

 とはいえ、どんどん外部のライブラリを持ってきて使えばいい……と考えるのも危険です。ライブラリとライブラリがいつコンフリクトするか分からないし、ある日突然使えなくなるライブラリもないとはいえません。とても悩ましいですね。

「IDE? そんなもの要らないよ」派

 amachangさんによるデブサミ2007での「JavaScriptの現在と未来」のプレゼンテーション資料です。動きのある説得力のあるプレゼンテーションで、内容もよくまとまっているので紹介します。

 特に「IDE? そんなもの要らないよ。愛用のエディタで書けばいい!」のような主張は、実際に秀丸でJavaScriptを書いている自分の状況にも合致して説得力がありました。また、クラスなど要らないと力強く言い切っているのも好感が持てますね。


Ajax うきうき Watch バックナンバー


AjaxでつくるインタラクティブWebアプリケーション

AjaxでWebフォトアルバムを、ゼロから開発する。ライブラリを用いて機能を作り上げていくステップを、具体的に解説する

最終更新 2006/3/17

古くて新しいAjaxの真実を見極める
「Webインターフェイスの新しい手法」「画期的なWebアプリケーションの仕組み」であるとして開発者たちの人気を集めるAjaxとは何なのか、その真実を見極めてみよう
最終更新 2005/8/2

ホワイトペーパーTechTargetジャパン

リッチクライアント & 帳票 フォーラム 新着記事

@ITメールマガジン 新着情報やスタッフのコラムがメールで届きます(無料)

RSSフィード

スキルアップ/キャリアアップ(JOB@IT)

お勧め求人情報

キャリアアップ 〜JOB@IT
@IT Special -PR-
  企業の仮想化に足りない“発想”とは?
仮想化運用管理のキモは意外なところに!

New!
  操作もマニュアルも分かりやすい!
ユーザー視点で開発されたPC管理ツール

New!
  仮想化すればコストは削減できるか?
仮想化に必要な「3つの視点」を解説する

  セキュリティを知り尽くす上野氏が登壇!
@ITメールソリューションLive! in Tokyo

  運用管理の課題を“2つの観点”から分析
ユーザー満足度の高い「仮想環境」とは?

  世界に通用するストレージの作り方とは?
製品に込めた思いを富士通の開発者に聞く

  OSSで手間も時間も、障害も減った――
「マピオンの事例」オープンソース活用法

  「ノートPCの持ち出し禁止」で大丈夫?
情報漏えいを防ぐ管理手法とインフラは?

  1日の処理を1秒に――MySQLの達人が語る
「コスト削減」できるチューニング

  ドキュメント作成を自動化して、SEの作業
効率を大幅アップ! Visio 2007の魅力

  急速に広がるHyper-Vでのサーバ仮想化
そのベストプラクティスをデルが解説

  @IT主催セミナーで語られた、「担当者に
求められるセキュリティ対策」をレポート

  @IT「Windows 7」 特設サイトオープン!
最新情報・移行ノウハウを公開しています