در این مطلب میخواهم شما را با نحوه بار گزاری ساعت و تاریخ سیستم سرور با استفاده از JQuery Ajax آشنا کنم.
در بعضی از سایتها با استفاده از جاوا اسکریپت تاریخ و ساعت جاری سیستم کلاینت به او نشان داه میشود.
این روش یک مزیت دارد: اول اینکه این کدها سمت کلاینت اجرا میشن و برای سرور بار اضافی ایجاد نمیکنن.
و یک عیب هم دارد: در صورتی که ساعت و تاریخ روی سیستم کلاینت تنظیم نباشد، همین ساعت و تاریخ نادرست برای او نمایش داده میشود. همین عیب میتواند باعث افت کیفیت وب سایت شود.
اما راهی هست که تاریخ و ساعت سیستم سرور برای کاربر نشان داده شود و آن هم استفاده از JQuery Ajax هست. به صورتی که هر ثانیه درخواستی برای یک handler فرستاده میشود و آن handler نیز ساعت و تاریخ روی سرور را باز میگرداند و این مقدار بازگشته شده را میتوان در تگی از صفحه وب نمایش داد.
مثال: ابتدا یک صفحه aspx میسازیم و تگ زیر را در آن قرار میدهیم:
ساعت و تاریخ بار شده از سرور در این تگ باید نشان داده شود.
سپس کدهای اسکریپت زیر را مینویسیم:
var auto_referesh = setInterval
(
function()
{
$.post
(
"GetDateTime.ashx",
function (result)
{
$('#datetime').html(result);
}
);
}, 1000
);
با نوشتن این کدها هر ثانیه یک بار، بوسیله Ajax درخواستی برای یک handler به اسم GetDateTime.ashx فرستاده میشود. وظیفه این handler برگرداندن تاریخ و ساعت فعلی سیستم سرور است. بعد از دریافت مقدار این مقدار از این handler، آنرا در تگ با شناسه datetime قرار میدهیم.
کد استفاده شده در handler هم به این صورت است:
<%@ WebHandler Language="C#" Class="GetDateTime" %>
using System;
using System.Web;
public class GetDateTime : IHttpHandler {
public void ProcessRequest (HttpContext context) {
context.Response.ContentType = "text/plain";
context.Response.Write(DateTime.Now.ToString());
}
public bool IsReusable {
get {
return false;
}
}
}
در انتها فایل ضمیمه این مثال را از این لینک دریافت کنید:
AjaxDateTime.zip