暖冬傾向で、ゴルフ場の予約が多い!
100万ポイント山分け!1日5回検索で1ポイントもらえる
>>
人気記事ランキング
ブログを作成
楽天市場
000000
HOME
|
DIARY
|
PROFILE
【フォローする】
【ログイン】
「東雲 忠太郎」の平凡な日常のできごと
新着記事一覧(全17284件)
過去の記事 >
2024.11.03
AJAXを使用して非同期通信を実装する方法
カテゴリ:
ASP.MET
AJAXを使用して非同期通信を実装する方法を、ASP.NETを使った簡単な例で示します。この例では、ユーザーがボタンをクリックすると、サーバーにリクエストを送り、結果を受け取って画面に表示します。
### 1. **ASP.NET Webフォームの構成**
#### 1.1. 必要なHTMLとjQueryのコード
**Default.aspx**
```aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="Default" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>AJAX Example</title>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$('#btnGetData').click(function () {
// 非同期通信の実行
$.ajax({
type: "GET", // HTTPメソッド
url: "DataHandler.ashx", // サーバーサイドのハンドラ
success: function (response) {
// 成功時に結果を表示
$('#result').html(response);
},
error: function (xhr, status, error) {
// エラー時の処理
alert("エラーが発生しました: " + error);
}
});
});
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Button ID="btnGetData" runat="server" Text="データを取得" />
<div id="result"></div>
</div>
</form>
</body>
</html>
```
### 2. **サーバーサイド処理**
次に、AJAXリクエストを処理するためのサーバーサイドのハンドラを作成します。このハンドラは、データを生成してクライアントに返します。
#### 2.1. ハンドラのコード
**DataHandler.ashx**
```csharp
<%@ WebHandler Language="C#" Class="DataHandler" %>
using System;
using System.Web;
public class DataHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
// ここでデータを生成または取得する
string responseData = "サーバーからのデータ: " + DateTime.Now.ToString();
// コンテンツタイプを設定
context.Response.ContentType = "text/plain";
// データを返す
context.Response.Write(responseData);
}
public bool IsReusable
{
get { return false; }
}
}
```
### 3. **解説**
- **jQueryのインポート**: jQueryのCDNからスクリプトを読み込み、jQueryを使用できるようにします。
- **AJAXのリクエスト**: ボタンがクリックされると、`$.ajax()`メソッドが呼ばれます。`url`には、データを取得するためのハンドラのURLを指定します。
- **成功時の処理**: サーバーからのレスポンスが成功した場合、`success`コールバック関数が実行され、結果が`#result`というIDの要素に表示されます。
- **エラーハンドリング**: 通信中にエラーが発生した場合は、`error`コールバック関数が実行され、エラーメッセージが表示されます。
### 4. **実行とテスト**
1. 上記のコードをASP.NETプロジェクトに追加します。
2. Webページを実行し、「データを取得」ボタンをクリックします。
3. サーバーからのデータが表示されることを確認します。
### 5. **結果の表示**
このサンプルでは、ボタンをクリックすることでサーバーからのデータ(現在の日時)を非同期で取得し、ページの一部を更新する方法を示しています。AJAXを使用すると、ページをリロードせずにサーバーと通信できるため、ユーザーエクスペリエンスが向上します。
この基本的な例を基に、さらに複雑なデータの取得や処理を行うことができます。必要に応じて、POSTメソッドを使用してデータを送信することも可能です。
お気に入りの記事を「いいね!」で応援しよう
いいね!
2
シェアする
Last updated 2024.11.03 02:09:35
ホーム
フォローする
過去の記事
新着記事
上に戻る
【毎日開催】
15記事にいいね!で1ポイント
10秒滞在
いいね!
--
/
--
次の日記を探す
おめでとうございます!
ミッションを達成しました。
広告を見てポイントを獲得する
※「ポイントを獲得する」ボタンを押すと広告が表示されます。
x
エラーにより、アクションを達成できませんでした。下記より再度ログインの上、改めてミッションに参加してください。
ログインする
x
X
© Rakuten Group, Inc.
X
共有
Facebook
Twitter
Google +
LinkedIn
Email
Mobilize
your Site
スマートフォン版を閲覧
|
PC版を閲覧
人気ブログランキングへ
無料自動相互リンク
にほんブログ村 女磨き
LOHAS風なアイテム・グッズ
みんなが注目のトレンド情報とは・・・?
So-netトレンドブログ
Livedoor Blog a
Livedoor Blog b
Livedoor Blog c
楽天ブログ
JUGEMブログ
Excitブログ
Seesaaブログ
Seesaaブログ
Googleブログ
なにこれオシャレ?トレンドアイテム情報
みんなの通販市場
無料のオファーでコツコツ稼ぐ方法
無料オファーのアフィリエイトで稼げるASP
ホーム
Hsc
人気ブログランキングへ
その他
Share by: