SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

ASP.NET AJAXで学ぶAJAX対応コントロール実装の基本

ASP.NET AJAXで学ぶAJAX対応コントロール実装の基本(前篇)

ASP.NET AJAX Controlの作成方法を学習する


  • X ポスト
  • このエントリーをはてなブックマークに追加

HelloAjaxControlExtenderコントロールの登録

 実際にWebページ上で利用するためにツールボックスにコントロールの登録作業を行います。前項目までの作業が完了した後で、[ビルド]-[ソリューションのビルド]を選択し、ExtenderコントロールのDLLを作成します。今回の手順どおりであれば、HelloAJAXControlプロジェクトの「bin\Release」フォルダ(設定により「Debug」フォルダの場合もあります)の直下に「HelloAJAXControl.dll」があります。

 続いてツールボックスにHelloAJAXControlExtenderコントロールを追加します。

 ツールボックス上で右クリックし、コンテキストメニューから[タブの追加]を選択し、適当な名前を付けます(今回はHelloAJAXControlとします)。

 作成したタブの上で再度右クリックし、コンテキストメニューから[アイテムの選択]を選択します。表示される[ツールボックス アイテムの選択]ダイアログの[参照]から上記の位置にある「HelloAJAXControl.dll」を開きます。

 以上の手順でタブ上に[HelloAJAXControlExtender]が追加されました。

Express Editionを利用している場合の手順
 ここではVisual Studio 2005を使い、1つのソリューションの中にプロジェクトとWebサイトを共存させていますが、Express Editionの場合はそれぞれ独立した製品となっているので、少し手間がかかります。
  1. VBかC#のExpress Edition上で[新しいプロジェクト]として[ASP.NET AJAX Control Project]を選択する。Express Edition上でコードを記述後、ビルドします。
  2. VWD(Visual Web Developer 2005 Express Edition)のIDE上で上記の手順に沿って設定を行うことで自作のExtenderコントロールを利用することができます。

Webページ上で配置し利用する

 既存のAJAX Control Extendeと同様にHTMLデザイナ画面に貼り付けて、TargetControlIDプロパティをButton1に設定して、TargetButtonIDプロパティをButton2に設定して実行します。

default.aspx(一部)
<%@ Register Assembly="HelloAjaxControl"
    Namespace="HelloAjaxControl.HelloAjaxControl" TagPrefix="cc1" %>

中略

    <form id="form1" runat="server">
        <ajaxToolkit:ToolkitScriptManager
            ID="ScriptManager1" runat="server" />
        <div>
        <asp:UpdatePanel ID="UpdatePanel1" runat="server">
            <ContentTemplate>
                <asp:Label ID="Label1" runat="server"
                           Text="イベントトリガーLabel"
                           BackColor="#ccccff"></asp:Label>
                <asp:Button ID="Button1" runat="server"
                            Text="Button" />
                <cc1:HelloAjaxControlExtender
                    ID="HelloAjaxControlExtender1"
                    runat="server" DisplayText="SampleText"
                    TargetButtonID="Button1" TargetControlID="Label1">
                </cc1:HelloAjaxControlExtender>
            </ContentTemplate>
        </asp:UpdatePanel>
        </div>
    </form>
タグcc1について
 上のソースの中で自作のExtenderコントロールのタグがcc1となっていることが分るかと思いますが、タグがcc1になっているのは上部に書かれている<%@ Register ~~~ %>ディレクティブが関係しています。
 HTMLデザイン画面上でタブから直接HelloAJAXControlExtenderコントロールを張り付けた際にWeb.Configファイル上で登録していないので、<%@ Register ~~~ %>ディレクティブが自動的に記述されます。<%@ Register ~~~ %> ディレクティブはコントロールのタグプリフィックスとアセンブリの配置を宣言するので、もし自分が作成した自作のExtenderコントロールを利用する場合はtagPrefixを変更しましょう。

 実行すると、LabelコントロールとButtonコントロールの2つだけが表示されます。Labelコントロール上にマウスを移動させると、Hello,AJAX Control Extenderというダイアログが表示され、その後にButton2が利用不可能になります(図3~5 )。

まとめ

 以上今回は、Control Toolkitを利用したコントロール作成の基礎を学びました。次回は引き続き、今回作成したHelloAjaxControlExtenderコントロールを拡張する中で、コントロール作成に必要な理解を深めたいと思います。

次の記事

参考資料

  1. ASP.NET AJAX(公式ページ:英語)
  2. ASP.NET AJAX Control Toolkit(ドキュメント:英語)
  3. ASP.NET AJAX > Client Reference
  4. Shawn Burke's Blog
  5. Delay's Blog

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
ASP.NET AJAXで学ぶAJAX対応コントロール実装の基本連載記事一覧
この記事の著者

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

WINGSプロジェクト ナオキ(ナオキ)

WINGSプロジェクトについて> 有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS Twitter: @yyamada(公式)、@yyamada/wings(メンバーリスト) Facebook

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/1544 2007/08/10 17:50

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング