解説実例で学ぶASP.NETプログラミング第2回 トップ・ページ構築で理解するASP.NETの特長 小田原 貴樹(うりゅう)2003/02/01 |
![]() |
■残りのデザイン作成と、ロールオーバーの追加
さて、ひとしきりGridLayouyPanelコントロールに感心したところで、作成したメニューはじゃまにならない位置に移動しておき、残りの画像を配置していこう。配置が済んだら、メニューの上に重ねてみる。具体的な作業は以下のとおり。
![]() |
| 上部メニューへの画像の配置:手順1 |
| ソリューション・エクスプローラから「img2.gif」をドラッグ&ドロップする。同じように残りの「img3.gif」、「img4.gif」、「img9.gif」をドラッグ&ドロップで適当に配置する。 |
![]()
![]() |
| 上部メニューへの画像の配置:手順2 |
| 各画像の位置基準になる「img2.gif」を選択し、[style]プロパティ・ボタンを押す。 |
![]()
![]() |
| 上部メニューへの画像の配置:手順3 |
| [スタイル ビルダ]ダイアログの中から[位置]を選択し、[上]を「0」「px」、[左]を「0」「px」にする。 |
![]()
![]() |
| 上部メニューへの画像の配置:手順4 |
| 左上に位置が設定された[img2.gif]を基準に、[img3.gif]をドラッグ&ドロップで隣り合う適当な位置にまず配置してから、ピッタリくっつけるためにキーボードのカーソル・キーで微調整を行う。 |
![]()
![]() |
| 上部メニューへの画像の配置:手順5 |
| 前の手順で作成していたメニュー・ボタン群全体を配置のため選択し、GridLayouyPanelコントロールのスタイル・ビルダを表示する。 |
![]()
![]() |
| 上部メニューへの画像の配置:手順6 |
| コントロール同士を重ね合わせるためには、前面に表示されるコントロールのZインデックスを、背面に表示されるコントロールより大きくする必要がある。VS.NETは100から配置した順にZインデックスを割り振っていくので、150にしておけば確実に前面に表示されるだろう。 |
![]()
![]() |
| 上部メニューへの画像の配置:手順7 |
| Zインデックスを変更した上で、「img2.gif」の前面にメニュー・ボタン群をマウスで適当に配置し、細かな微調整をカーソル・キーで行う。 |
![]()
![]() |
| 上部メニューへの画像の配置:手順8 |
| 残りの「img4.gif」と「img9.gif」を同じようにマウスとカーソル・キーで配置し、完了した画面 |
デザイナ上での配置の基本は、取りあえずマウスで適当な位置に配置して、細かな位置合わせはキーボードのカーソル・キーを使って行うというものだ。画像やほかのコントロールとの重ね合わせの必要がある際には、前述のとおりGridLayouyPanelコントロールを利用し、きっちりとした表や、間隔を均一にして配置したい場合には、HTMLコントロールのTABLEコントロールと組み合わせるのが効果的だ。こうしたWebデザインを、VS.NET上のデザイナで極力処理し、HTMLを直接記述せずにすめば、Webアプリケーション作成の効率は格段に上がると思われる。
一通りの画像配置が完了したら、先ほどと同じようにロールオーバーの処理を行う。説明を繰り返すことはしないが、コードは以下のとおりであるので参照してほしい。
宣言部分末尾に追加
Public CCNT As New CCONT()
Page_Loadメソッド内に追加
CCNT.RLBTN(TM1, "bo15.gif", "bo15_2.gif")
CCNT.RLBTN(TM2, "bo16.gif", "bo16_2.gif")
…省略…
CCNT.RLBTN(TM5, "bo19.gif", "bo19_2.gif")
CCNT.RLBTN(TM6, "bo20.gif", "bo20_2.gif")
ロールオーバーに関するメソッドをクラス化しておくことで、どこで使用する際にも宣言するだけで利用できるようになる。筆者自身もオブジェクト指向化したASP.NETを完全に理解しきっているわけではないが、取りあえずクラスそのものを、同種のメソッドを取りまとめる名前空間として利用することぐらいは簡単にできると思う。
次回予告
一般的にショッピング・サイトのトップ・ページは、ほかのページに比べて構築に時間がかかる。今回作成した上部フレーム・ページと左部フレーム・ページは、トップ・ページの構成要素でありながらサイト全体のナビゲーションをつかさどるメニューの機能を持っている。こうしたメニュー・ページも作成する必要性が、トップ・ページ作成に時間がかかる理由だろう。
さて、次回はメイン・フレーム・ページの作成……と行きたいところなのだが、メイン・フレーム・ページにはデータベースとの接続が必要な、商品情報を表示するための構成要素がある。次回はメイン・フレーム・ページを作成するための前準備として「ADO.NET」、特に「データセット接続」に関するクラスの作成や解説を行いたい。
「ADO.NETのデータセット接続」は、ASPからASP.NETへの移行の中で最も変化が著しい部分で、うまく使いこなせていない方も多いと思う。VS.NETベースでのビジュアルなデータベース接続について「ASP.NET実践講座流」にざっくりと、分かりやすく解説させていただくので、ご期待いただきたい。
ちなみに、蛇足だが……次回は早い(笑)! 絶対に早い! あまりお待たせせずに第3回をお届けすることをお約束して、第2回を終了させていただく。![]()
| ■追加情報 その1 | |||
|
「参考になる.NETなソフト紹介」 まだまだ市場で目にすることが少ない「.NET Frameworkで作成されたソフト」だが、筆者がこの講座を執筆する上で欠かせないソフトの1つがこれだ。この講座では、今回から「で○るシリーズ」を思わせるほど(言い過ぎか?)画面写真を掲載しているが、この面倒な画面キャプチャをサポートしてくれているのが、グルーソフトウェアの「Click! レコーダー」(http://www.gluesoft.co.jp/ClickRec/)だ。 雑誌などでも紹介されているのでご存じの方も多いと思うが、とにかくよくできている。驚くばかりだ。操作を自動的にどんどんキャプチャしてくれるのはもちろんのこと、赤い枠なども自動的に操作対象のコントロールに付属される。 しかも.NET Frameworkで開発された「オブジェクト指向」ベースのソフトであるため、キャプチャされた画像に自動で追加された赤枠は、キャプチャ後に範囲を拡大・縮小できる。例えば、あるテキスト・ボックスに追加された赤枠を拡大していくと、コントロール→コントロール・コンテナ→ウィンドウという具合にクラス・ライブラリをさかのぼっていく様が確認できるだろう。こういった機能こそ.NET Frameworkの真髄であり、これまでのプログラミング技術では難しかったものである。 プログラマ&SEの方で、マニュアル作成に迫られている人は多いと思うが、このソフトを使えば画面を張り込む作業が大幅に削減できるだろう。百聞は一見にしかず、.NET Frameworkで完全に作成されたソフトというのが、どれほどのパワーを持つのかを感じるためだけにでも、ぜひ試してみてほしい。昨年の6月にはすでにシェアウェアとして発表されていたこのソフト、技術者としてその出来栄え・新しい技術に対する積極的なアプローチに、筆者は大いなる敬意を払いたいと思う。 |
|||
| ■追加情報 その2 | |||
|
「ASP.NETで作成されたショッピング・サイト紹介」 というか、この講座の解説ベースになっているV-STORE.NETという、筆者が作成したショッピング・サイトの構築システムで作成したサイトを紹介しようという手前味噌なコーナーでごめんなさい(笑)。実稼働しているショッピング・サイトでは、業種業態によって機能やデザインなどをカスタマイズしているので、ASP.NETがどこまでできるのかを知ってもらうために参考にしていただければ幸いである。
宝石のショッピング・サイトということで、とにかく商品画像にこだわってサイトを構成しているのが特徴といえるかと思う。V-STOREのデモサイト「VS屋」とは、細かく違う部分が多々あるので、イメージ&ビジュアル中心のショッピング・サイトのサンプルということで、参考にしていただきたい。 |
| INDEX | ||
| 実例で学ぶASP.NETプログラミング | ||
| 第2回 トップ・ページ構築で理解するASP.NETの特長 | ||
| 1.フレーム・ページによるトップ・ページの構築 | ||
| 2.左部フレーム・ページの作成(1) - テーブルの作成 | ||
| 3.左部フレーム・ページの作成(2) - メニュー・ボタンの作成とセル調整 | ||
| 4.左部フレーム・ページの作成(3) - ロールオーバー・メソッドの作成 | ||
| 5.上部フレーム・ページの作成(1) - GridLayouyPanelコントロールの利用 | ||
| 6.上部フレーム・ページの作成(2) - 残りのデザイン | ||
| 「解説 :実例で学ぶASP.NETプログラミング」 |
ホワイトペーパー(TechTargetジャパン)
- .NET TIPS - .NET開発のテクニックとヒント集 - (2010/3/18)
− GridViewコントロールを階層表示させるには?
− Windowsフォームのボタンに画像を表示するには?
− C#でnullチェックを簡潔に行うには? - Chapter15:LINQとクエリ式 (2010/3/17)
C# 3.0の目玉機能であるLINQについて、さまざまな記述例を交えながら徹底解説。書籍『[完全版]究極のC#プログラミング』より転載 - VBラムダ式 基礎文法最速マスター (2010/3/16)
今度はVB。ラムダ式の基礎文法を、短い説明と簡単なコードでまとめる。「ラムダ式、どう書くんだっけ?」という場合の簡易リファレンスとして活用できる - ASP.NET MVC 2がリリース (2010/3/15)
ASP.NET MVC 2の正式版(VS 2008のASP.NET 3.5向け、VS 2010には標準で含まれる予定)のリリースについてのお知らせ
|
|
スキルアップ/キャリアアップ(JOB@IT)
スポンサーからのお知らせ
- - PR -
| 「いつかは壊れるサーバ」そんな故障に 迅速で安価に手軽に対応する方法とは? New! |
| 「特権ユーザー」の事件を防げ! 万能権限を持つユーザーの管理方法とは? New! |
| 仮想環境の構築とデータ保護の特効薬?! 実績と信頼性の高いパッケージで安心運用 |
| 仮想環境のバックアップもこれまでどおり 「まるごと取ってまるごと戻す」簡単運用 |
| おばかアプリ選手権、第4弾開催中!! ムダにカッコよくてくだらない作品求ム! |
| 社内ファイルサーバを“クラウド”に統合 VPN直結「クラウド型ストレージ」を紹介 |
| その数、なんと400台以上! グループ内 サーバの「統合管理」によるメリットは? |
| 美人!? まあまあ? 気になる いやし系!! PV急増で「美人時計」がとった手段とは? |
| 進化を続ける富士通ストレージETERNUS DX 製品開発者の自信を裏付けるものとは何か |
| 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |
- - PR -
お勧め求人情報

**先週の人気講座ランキング**
〜CCNA編〜
| ◆ | TomcatやJBossなどAPサーバ環境に関する 情報を集約! “業務”用APサーバ大百科 New! |
| ◆ | 一気に解説! 最新のクラスタストレージ 「RAIDを超えたストレージ基準」……など New! |
| ◆ | クラウド的ユーザー体験の変化は脅威か? 仮想化技術を使いこなす運用管理術を紹介 New! |

| ◆ | 上司や部下、部署内メンバーとの情報共有 を“ガラッ”と変えるコラボツールとは? New! |
| ◆ | おばかアプリ選手権、第4弾開催中!! ムダにカッコよくてくだらない作品求ム! |
| ◆ | 社内ファイルサーバを“クラウド”に統合 VPN直結「クラウド型ストレージ」を紹介 |

| ◆ | Twitterのアカウントはなぜ突破された? メールによる新手の攻撃手法とその対策 |
| ◆ | もう仮想化のお試しフェイズは終わりだ! Hyper-V 2.0が基幹システムも仮想化 |
| ◆ | 美人!? まあまあ? 気になる いやし系!! PV急増で「美人時計」がとった手段とは? |

| ◆ | クライアント企業から求められる人材 ⇒IT技術と経営戦略を併せ持つ「戦略家」 |
| ◆ | .NET編集長が実践する「技術情報検索術」 サンプル・コードを簡単に探す“技”は? |
| ◆ | 業務効率と情報セキュリティ対策を両立! 手間なく確実に機密情報を守る方法とは? |

| ◆ | 進化を続ける富士通ストレージETERNUS DX 製品開発者の自信を裏付けるものとは何か |
| ◆ | 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |

| ◆ | 【CTC事例】約30の基幹システムを統合! 膨大なバッジジョブを制御した方法は? |
| ◆ | 仮想化すればコストは削減できるか? 仮想化に必要な「3つの視点」を解説する |
| ◆ | その数、なんと400台以上! グループ内 サーバの「統合管理」によるメリットは? |
















