gihyo.jp » DEVELOPER STAGE » 特集 » jQueryではじめるAjax » 第4回 検索キーワードを提案するSuggest機能の実装

jQueryではじめるAjax

第4回 検索キーワードを提案するSuggest機能の実装

今回は,検索文字列に関連するキーワードを提案するSuggest機能を実装したいと思います。

実装の前に

Suggest機能の実装に入る前に,第3回までのプログラムをちょっと整理しましょう。第3回までの実装では,とりあえずグローバルな名前空間に関数を追加していました。しかし,名前空間がどんどん汚染されよくありません。必要なものだけをグローバルな名前空間に追加しましょう。

スコープを隠蔽する

jQueryにならって,スコープを隠蔽してみることにします。次のように無名関数を使って実装します(リスト1)。

リスト1 スコープの隠蔽

(function(){
    // (1) このスコープは公開されない 
    var local = ・・・

    // (2) 必要なものだけを公開する 
    window.global = ・・・
})();

無名関数の定義(function(){})と,実行()を同時に行っています。 リスト3-(1)のlocalという変数は無名関数のローカルスコープにあるため,外部から直接参照することはできません。 リスト3-(2)のglobalのようにwindowオブジェクトに追加することにより,外部に参照を公開することができます。

Youtubeコンストラクタ関数の定義

Youtubeというコンストラクタ関数を作成し,それを基にした新しいオブジェクトをwindowオブジェクトに追加します。 第3回までのページロード時以外の実装はとりあえずここに押し込めることにします(リスト2)。

リスト2 Youtubeコンストラクタ関数

(function(){
    // コンストラクタ関数の定義 
    var Youtube = function() {
        ・・・
    }
    Youtube.prototype = {
        ・・・
    }

    // 名前空間 window.yt に公開 
    window.yt = new Youtube();
})();

これで,名前空間の汚染は最小限になりました。

今回は,単純に名前空間 window.yt という名前空間に実装を押し込めただけで,コンストラクタ関数を作成した意味があまりありません。 必要に応じて実装を拡張してください。

外部ファイル化

さらにこの実装を, Youtube.jsファイルとして外部ファイルに移動しました。 これで少しすっきりしましたね。

Suggest機能

それでは,Suggest機能の実装に入りたいと思います。

動作イメージ

検索テキストボックスに文字列を入力すると,検索テキストボックスの下に関連するキーワードが表示されます(図1)。 Suggest機能とは,このようにキーワードを提案(Suggest)して,検索を補助する機能です。

Suggest機能

機能概要

今回実装する機能の要件は次のとおりです。

  • 検索テキストボックスに文字列を入力すると,500ミリ秒後に関連するキーワード(以下 Suggest)を表示する。
  • Suggestが表示されていない場合,検索テキストボックスで「↓」を押すとSuggestを表示する。
  • Suggestが表示されている場合,検索テキストボックスで「↓」を押すとSuggestにフォーカスを移動する。
  • Suggestを選択すると,検索テキストボックスに選択したSuggestを設定する。
  • Suggestをダブルクリックすると,検索テキストボックスにダブルクリックしたSuggestを設定し,検索する。
  • ESCキーを押すとSuggestを閉じる。
  • Suggestがない場合は何も表示しない。

Suggestデータ

Youtube APIにはSuggest用のAPIやデータは用意されていません。 今回は,動画に設定されたキーワード(feed.entry[n].media$group.media$keywords.$t)をSuggestのデータとして使います。

著者プロフィール

池田正一(いけだまさかず)

仕事ではもっぱらJavaを使い,たまにC/C++を書かされ,WebサービスをRubyで開発するプログラマ。ドラえもん好きでドラえもんSuperDatabaseの管理人。stacktrace.jpにて頭の中のStackを出力中。

コメント

コメントの記入

パスサポ

多数の情報処理技術者試験対策書籍の発行実績を誇る技術評論社がお届けする,資格試験合格サイト「めざせ! 情報処理試験 パスサポ」が開設されました。

ピックアップ

サクセスストーリーに続く,快適サーバー運用管理のヒント!

データの増大,煩雑な管理,システムダウン,セキュリティなど,迫りくる課題からシステム管理者の負担を軽くするポイントを解説します。

gihyo.jp インフラエンジニア情報局

ネットワークやITにかかわるあらゆる業種で必要とされるインフラエンジニアに向けた技術情報や心構え,その魅力について多角的に紹介。

テストエンジニア ステーション

いま,ITに関わるあらゆる開発業務で注目されつつあるテスト系エンジニアをターゲットにしたコンテンツサイトを展開します。

一行クイックアンケート

gihyo.jpで取り上げてほしいネタは?

※検索はページ右上の検索ボックスをご利用ください。

その他の連載

2010年版SEO体得講座

本連載では,いまや企業サイトの戦略の1つとして欠かすことのできないSEOについて,最新トレンドからすぐに使えるTipsまでを紹介します。

小型Linuxサーバの最高峰 OpenBlockS 600活用指南

搭載メモリの増加,CPUクロックの向上など,あらゆる面が強化された期待の新モデルOpenBlockS 600。この記事ではOpenBlockS 600の紹介から,活用するためのさまざまなノウハウを紹介していきます。

はじめMath! Javaでコンピュータ数学

プログラミング言語入門者向けに,知っていると役立つ数学的トピックスを紹介します。簡単な演習問題と解説で,即活用できる知識を目指します。

教科書には載っていない ネットワークエンジニアの実践技術

ネットワークエンジニア,インフラエンジニアのトラブル対応には,時には「教科書通りにいかない」テクニックが必要となります。資格試験では得られないこうした実践的な技術について,実例を元に紹介します。

Googleケータイ,世に現る

2008年9月,Googleが中心となって開発されている「Android」を採用した携帯電話「T-Mobile G1」が発表されました。本連載ではT-Mobile G1を中心にGoogleケータイに迫ります。

モバゲーオープンプラットフォームに挑戦!――面白法人カヤック流モバゲーオープンプラットフォーム企画と開発のイロハ

2010年1月にリリースとなったモバゲーオープンプラットフォーム。その制作企業であるカヤックが,アイデアを企画に落とし込み,開発までのノウハウを紹介します。

プロトタイピングツールSketchFlowを用いた,Silverlightアプリ開発

SketchFlowプロトタイプ作成からアプリケーション開発までをExpression Blend 3を使って実践的に解説します。

Ubuntu Weekly Recipe

Ubuntuの強力なデスクトップ機能を活用するための,いろいろなレシピをお届けします。

連載一覧

gihyo.jp

  • DEVELOPER STAGE
  • ADMINISTRATOR STAGE
  • WEB+DESIGN STAGE
  • LIFESTYLE STAGE
  • SCIENCE STAGE
  • NEWS & REPORT

書籍案内

  • 新刊書籍
  • 書籍ジャンル一覧
  • 書籍シリーズ一覧
  • 新刊ピックアップ
  • ロングセラー
  • 電脳会議

定期刊行物一覧

  • Software Design
  • WEB+DB PRESS
  • Web Site Expert
  • 組込みプレス

最近のコメント