نمایش افکت fade in با ای جکس (Ajax)

تا این قسمت از آموزش های مقدماتی ای جکس (Ajax) گفتیم این زبان تکنیک غیرهمزمانی در وب است که از ترکیب برنامه نویسی جاوا اسکریپت و XML شکل گرفته و به طور خلاصه هدف از معرفی آن جلوگیری از بارگذاری مجدد صفحات وب در هنگام ارسال درخواست ها و صرفه جویی در میزان اطلاعات رد و بدل شده بین مرورگر کاربر و سرور است، استفاده به جا از ای جکس در مجموع به زیبایی و کارایی رابط کاربری (User Interface) برنامه های تحت وب کمک می کند، همچنین در مباحث قبل نحوه ارسال و دریافت اطلاعات با متد POST و GET در ای جکس را شناختیم و حتی توانستیم تصویری را به عنوان در حال پردازش (Loading) در حالتی که onreadystatechange برابر 0 تا 4 بود به کاربر نمایش دهیم، در ادامه آموزش ها و در این مطلب می خواهیم دانستنی های خود از ای جکس را با قابلیتی دیگر کامل تر کنیم و ببینیم چگونه می توان پس از دریافت اطلاعات درخواست ای جکس از سرور، نتیجه را با افکت fade in (ظاهر شدن تدریجی محتوا از حالت بی رنگ به واضح) نشان دهیم.
ساخت افکت fade in با ترکیب جاوا اسکریپت و CSS
قبل از اینکه بتوانیم افکت fade in را در هنگام نمایش نتیجه درخواست ای جکس به طور مثال در بلاک div نمایش دهیم، باید افکت را به صورت تابع در جاوا اسکریپت تعریف کنیم، برای این کار یکی از راه حل ها استفاده از خاصیت opacity در CSS است (opacity برای ایجاد حالت شفافیت در CSS3 معرفی شده است)، در نمونه کد زیر نحوه ایجاد حالت انیمیشن با خاصیت opacity و دستورات جاوا اسکریپت را ملاحظه می کنید.
<script>
var element = document.getElementById('result');
//1000 میلی ثانیه برابر با 1 ثانیه
var duration = 1000;
//میزان فریم های انیمیشن از حالت شفافیت کامل تا وضوح کامل
var steps = 20;
function setOpacity(level){
element.style.opacity = level;
element.style.mozopacity = level;
element.style.khtmlopacity = level;
element.style.filter = "alpha(opacity=" + (level * 100) + ");";
}
function fadeIn(){
for(i = 0; i <= 1; i += (1 / steps)) {
setTimeout("setOpacity(" + i + ")", i * duration);
}
}
</script>
توضیح:- در تابع setOpacity مقادیر شفافیت از آرگیومنت level دریافت و به بلاک div هدف نسبت داده می شود (آی دی بلاک div با متد document.getElementById در متغیر element تعریف شده است).
- در تابع fadeIn در حلقه for طی 20 دور تکرار، حالت افکت را ایجاد می کنیم و در واقع تابع setOpacity را با مقادیر متفاوت در هر دور فراخوانی می کنیم تا در نهایت نتیجه به صورت انیمیشن نمایش داده شود، این فراخوانی با تابع setTimeout صورت می گیرد که در هر دور با توجه به محاسبات، مقادیر متفاوتی به عنوان آرگیومنت آن تنظیم می شود.
- حالت های متفاوت style.opacity، style.mozopacity و style.khtmlopacity برای سازگاری با مرورگرهای مختلف است.
- دقت کنیم در حالت معمول الزاما باید کدهای جاوا اسکریپت بالا را بین تگ body و بعد از بلاک div هدف درج کنیم، مگر اینکه تابع در رویدادهایی مانند window.onload فراخوانی شود.
فایل ajax-loading-fade.php، دریافت درخواست و ایجاد خروجی در سرور
می دانیم که ای جکس واسط بین مرورگر و سرور است و لذا دو فاکتور در هر درخواست نقش ایفا می کنند، کدهای سمت کاربر و کدهای سمت سرور، برای تست و بررسی نحوه کارکرد افکت fade in ابتدا کد سمت سرور زیر را در فایلی با نام فرضی ajax-loading-fade.php درج و فایل را در یک دایرکتوری (فولدر) ذخیره می کنیم، در این نمونه کد با تابع rand در PHP اعدادی اتفاقی تولید و آنها را به متغیر code نسبت می دهیم، در نهایت نیز با دستور echo خروجی را چاپ و در پاسخ درخواست ارسال می کنیم.
<?php
$code = rand(10000, 99999);
echo 'کد انتخابی شما عدد ' . $code . ' است!';
?>
به این دستورات PHP که در سرور اجرا می شوند در اصطلاح کدهای سمت سرور می گوییم.فایل ajax-loading-fade.html، ارسال درخواست، دریافت و نمایش نتیجه
در کنار فایل PHP و کدهای سمت سرور قاعدتا باید فایل HTML و کدهای سمت کاربر نیز داشته باشیم تا درخواست ای جکس را ارسال و نتیجه را از سرور دریافت کند، نمونه کدهای زیر حاوی تنظیمات جاوا اسکریپت و ای جکس است که درخواست را به سرور (فایل ajax-loading-fade.php) ارسال، پاسخ را دریافت و نتیجه را به صورت افکت fade in نمایش می دهد.
<!DOCTYPE html>
<html lang="fa">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>وبگو | نمایش نتیجه درخواست ای جکس با افکت fade in</title>
<!-- Webgoo.ir -->
<style>
body {
direction: rtl;
font-size: 12px;
font-family: Tahoma, Geneva, sans-serif;
}
#message {
height:20px;
}
#result {
background-color: #666;
color: #FFF;
width:190px;
padding:4px;
}
</style>
<script>
function ajaxRequest(){
var xmlHttp;
try{
//Firefox, Chrome, Opera, Safari
xmlHttp = new XMLHttpRequest();
return xmlHttp;
} catch (e){
try{
//Internet Explorer
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
return xmlHttp;
} catch (e){
try{
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
return xmlHttp;
} catch (e){
alert("مرورگر شما از ای جکس پشتیبانی نمی کند!");
return false;
}
}
}
}
var div = 'result';
var message = 'message';
var loading = '<img src="loading.gif" alt="loading" height="16" width="16"> کمی صبر کنید...';
var url = 'ajax-loading-fade.php';
function changeCode(){
var xmlHttp = ajaxRequest();
var elm_message = document.getElementById(message);
var elm_div = document.getElementById(div);
xmlHttp.onreadystatechange = function(){
if(xmlHttp.readyState > 0 && xmlHttp.readyState < 4){
elm_message.innerHTML = loading;
}
if(xmlHttp.readyState == 4){
elm_div.innerHTML = xmlHttp.responseText;
fadeIn();
elm_message.innerHTML = '';
}
}
xmlHttp.open("POST", url, true);
xmlHttp.send();
}
</script>
</head>
<body>
<noscript>جاوا اسکریپت در مرورگر شما پشتیبانی نمی شود یا غیرفعال است!</noscript>
[<a href="#" onclick="changeCode();">تعویض کد</a>]<br><br>
<div id="message"></div><br>
<div id="result">کد جدید اینجا نشان داده خواهد شد!</div>
<script>
var element = document.getElementById('result');
//1000 میلی ثانیه برابر با 1 ثانیه
var duration = 1000;
//میزان فریم های انیمیشن از حالت شفافیت کامل تا وضوح کامل
var steps = 20;
function setOpacity(level){
element.style.opacity = level;
element.style.mozopacity = level;
element.style.khtmlopacity = level;
element.style.filter = "alpha(opacity=" + (level * 100) + ");";
}
function fadeIn(){
for(i = 0; i <= 1; i += (1 / steps)) {
setTimeout("setOpacity(" + i + ")", i * duration);
}
}
</script>
<hr>
برای ارسال درخواست ای جکس از متد POST استفاده کرده ایم، با توجه به اینکه در سمت سرور پارامتری دریافت نمی شود استفاده از متد GET نیز مشکلی ایجاد نمی کند.
</body>
</html>
پیش نمایش آنلاینتوضیح:
- شیوه استفاده شده در این نمونه کد شباهت زیادی به مثال های گذشته دارد، با این تفاوت که در اینجا کد جاوا اسکریپتی برای ایجاد افکت fade in به انتهای صفحه اضافه شده است.
- برای فراخوانی تابع افکت پس از true شدن xmlHttp.readyState == 4، با قرار دادن ()fadeIn این کار را انجام داده ایم.
- برای نمایش پیام در حال پردازش و نتیجه درخواست ای جکس، از دو بلاک متفاوت (با آی دی message و result) استفاده کرده ایم.
- عناوین بلاک ها و توابع، فرضی و سلیقه ای است، می توانید متناسب با نیاز و سلیقه خود آنها را تغییر دهید.

ذخیره و نمایش اطلاعات فایل با ای جکس (Ajax) و PHP
نمایش پیام در حال بارگذاری با ای جکس (Ajax)
ارسال و دریافت اطلاعات با متد GET و POST در ای جکس (Ajax)
آموزش ای جکس (Ajax)، تکنیک غیرهمزمانی در وب
فریم ورک های ای جکس (Ajax Frameworks)


setTimeout("setopacity(" + i + ")", i * duration);
ما تابع Setopacity رو ذیل for بیست مرتبه اجرا می کنیم و هر دفعه مقدار i رو بهش می دیم دیگه درسته؟این + i + یعنی چی ؟
اگه فقط i رو بنویسیم ، بازم کار نمی کنه؟
الان در این خط
setTimeout("setopacity(" + i + ")", i * duration);
به جای +i+ می توان از i++ استفاده کرد؟یه سوال دارم
منظورتون از + i + در قسمت
setTimeout("setopacity(" + i + ")", i * duration);
چیست؟و همین طور
element.style.filter = "alpha(opacity=" + (level * 100) + ");";
ممنون میشم اگر راهنماییم کنید.تشکر از سایت بسیار عالیتان
element.style.filter برای تنظیم حالت محوی در مرورگر اینترنت اکسپلورر کاربرد دارد.
- به سوالات کلی، زمانبر، مبهم و مشکلاتی که تلاشی برای رفع آنها نکرده باشید پاسخ مختصر داده شده یا به بخش برنامه نویسی اختصاصی ارجاع داده می شوند.
- کدها و اسکریپت های طولانی را ترجیحا در یک صفحه وب آنلاین یا به صورت حساب موقت و آزمایشی قرار دهید تا امکان بررسی دقیق مشکل و خطایابی میسر باشد.
- تمام دیدگاه های ارسالی خوانده شده و برای هر کاربر مدت زمان لازم جهت پاسخگویی در نظر گرفته می شود، لطفا از طرح سوالات متعدد در بازه زمانی کوتاه خودداری کنید.