PDA

توجه ! این یک نسخه آرشیو شده میباشد و در این حالت شما عکسی را مشاهده نمیکنید برای مشاهده کامل متن و عکسها بر روی لینک مقابل کلیک کنید : Ajax



persian.developer
February 5th, 2010, 22:32
اِیْ‌جکس یا آژاکس (AJAX؛ سرواژهٔ «Asynchronous JavaScript And XML»)، مجموعه‌ای از استانداردها و فناوري‌های وب است که به کمک آنها می‌توان برنامه‌هایی مبتنی بر وب تولید کرد که به آسانی با کاربران تعامل داشته باشند. با استفاده از این فناوریها و با کمک انتقال تکه‌های کوچک داده و اطلاعات از رایانهٔ خادم (Server)، صفحات وب از حالت منفعل خارج می‌شوند و واکنشهایی مناسب با رویدادها انجام می‌دهند. آژاكس معماری جدیدی برای برنامه‌های تحت وب است، که با سرعت بسیار زیادی در حال گسترش بوده، و کمتر کاربر اینترنت است که هنوز گذرش به یکی از صفحاتی که با این معماری ساخته شده‌اند نیفتاده، و از قابلیت‌های فوق‌العاده آن بهره‌مند نشده باشد. Gmail، Google Map، Google Suggest، Orkut، و اسامی آشنای دیگر، نمونه‌هایی هستند از کاربرد آژاكس. با استفاده از این معماری، صفحات وب تعامل بسیار خوبی با کاربران خواهند داشت. بعلاوه، مهم‌ترین مزیت این معماری این است که دیگر برای انجام هر کاری، لازم نیست صفحه وب دوباره بارگذاری شود. در این مقاله به بررسی تاریخچه، اصول، و شیوهٔ انجام کارها در این معماری خواهیم پرداخت.

مجموعه فناوریهای تشکیل دهنده آژاکس عبارتند از [۱]:
نمایش استاندارد با استفاده از اکس‌اچ‌تی‌ام‌ال و سی‌اس‌اس
نمایش پویایی و تعاملات با استفاده از مدل شیء‌گرای سند
تبادل و دستکاری داده‌ها با استفاده از XML و XSLT،
بازیابی داده‌ها بصورت غیر همروند با استفاده از XMLHttpRequest،
نهایتاً جاوااسکریپت برای سرهمبندی همه چیز با هم.

پیشینه
واژه آژاكس را برای اولین بار Jesse James Garrett در فوریه سال ۲۰۰۵ در مقاله Ajax: A New Approach to Web Applications استفاده کرد. اگرچه نام آژاكس برای نخستین بار در سال ۲۰۰۵ ابداع شد، اما تاریخچه اکثر فناوریهایی که به آژاکس منتهی شدند به حدود یک دهه قبل و ابتکارات مایکروسافت در اسکریپت نویسی از راه دور بازمی‌گردد. با این حال تاریخچه فناوریهایی برای بارگذاری غیرهمروند محتویات یک صفحه وب، بدون نیاز به بارگذاری دوباره صفحه، به عناصر IFRAME (که در سال ۱۹۹۶ در نسخه ۳ IE ارائه شد) و عناصر LAYER (که در سال ۱۹۹۷ در نسخه ۴ مرورگر Netscape ارائه شد، اما در نسخه‌های اخیر موزیلا متروکه شده‌است) باز می‌گردد. هردوی این عناصر، یک خصوصیت src دارند که می‌تواند یک آدرس URL خارجی را شامل شود و به این ترتیب اگر صفحه‌ای شامل یک کد جاوااسکریپت بارگذاری شود که صفحه والد را دستکاری می‌کند، نتیجه‌ای شبیه آژاكس خواهیم داشت.

اسکریپت نویسی از راه دور مایکروسافت (یا MSRS که در سال ۱۹۹۸ مطرح شد) جایگزین مناسب‌تری برای تکنیک‌های گذشته به نظر می‌رسید. در این روش، داده‌ها به‌وسیله یک Java Applet دریافت می‌شد، و در سمت کلاینت برقراری ارتباط به‌وسیله جاوااسکریپت انجام می‌گرفت. این روش در نسخه‌های ۴ و بعدتر اینترنت اکسپلورر و نت‌اسکیپ پشتیبانی می‌شود.

مایکروسافت در نسخهٔ ۵ اینترنت اکسپلورر شیء XMLHttpRequest را ارائه کرده و برای اولین بار در Outlook Web Access که در Microsoft Exchange Server ۲۰۰۰ ارائه شد، از این روش با استفاده از شی XMLHttpRequest بهره جست.

در نهایت با تغییر و تحولاتی که در این مسیر به وجود آمد و جایگزینی شیء XMLHttpRequest به جای Java Applet، اکنون روشی برای اسکریپ نویسی از راه دور متداول شده که آن‌را با عنوان آژاكس می‌شناسیم.

اما آنچه باعث شد پس از این مدت، ناگهان توجه‌ها به سمت آژاكس جلب شود، تمرکز شرکت گوگل بر این معماری بود. وب‌سایت‌هایی از قبیل Google Map، Gmail و Google Suggest پروژه‌هایی بودند که باعث شد توجه کاربران، چه کاربران عادی و چه کاربران حرفه‌ای، به نحوه کار آنها جلب شود.

آژاكس به عنوان معماری جدیدی برای وب
روش کار برنامه‌های کلاسیک وب چیزی شبیه این است: اکثر تعاملات کاربر با رابط کاربری باعث ارسال یک درخواست به سرور می‌شود. سرور پردازش‌های لازم را انجام داده و سپس یک صفحه HTML به کلاینت بازمی‌گرداند. این مدل بر اساس هدف اصلی وب، یعنی ایفای نقش یک رسانه برای ابرمتن است. اما آنچه وب را برای ابرمتن‌ها مناسب می‌کند، الزاماً آن را برای برنامه‌های نرم‌افزاری نیز مناسب نخواهد کرد[۱]. مسئله اینجاست که برنامه‌های وب برای کاربرد (Application) بودن طراحی نشده‌اند و این باعث شده‌است که در بسیاری موارد کاربر را نادیده بگیرند.

فرض کنید کاربر می‌خواهد در یک فروشگاه الکترونیک، مشخصات جنس بعدی را ببیند، یا یک جنس را به سبد خرید خود اضافه کند. اتفاقی که می‌افتد این است که برای انجام هریک از این کارها، چون نیاز است با سرور ارتباط برقرار شود، باید یک درخواست به سرور ارسال شده، سرور پردازشهای لازم را انجام دهد و سپس یک صفحه به عنوان نتیجه بازگرداند. کاربر هم در این میان می‌تواند با انگشتانش بازی کند!

گرچه ما به صفحات وب، با همین روند انجام فعالیت هاعادت کرده‌ایم، اما واقعا روش کلاسیک برنامه‌های وب، گرچه از نظر تکنیکی مزایای بسیاری دارند، اما مشکلات عمده‌ای هم دارند. یکی از عمده‌ترین مشکلات صفحات وب را می‌توان همروند کار کردن آنها دانست. (یعنی همین که وقتی درخواستی از سرور داریم، صفحه وب مقابلمان مسدود شده و باید منتظر بمانیم تا سرور کارش تمام شود و صفحه‌ای به عنوان پاسخ برگرداند).

ای‌جکس چیست
ای‌جکس یک تکنولوژی نیست؛ بلکه مجموعه‌ایست از تکنولوژی‌هایی که هر یک در جای خود تکنولوژی کامل و موفقی هستند، و اکنون به شکل جدیدی در کنار هم قرار گرفته و آژاكس را تشکیل داده‌اند [۲]. تکنولوژی‌هایی که در آژاكس از آن‌ها استفاده می‌شود عبارت‌اند از:
نمایش استاندارد با استفاده از XHTML و CSS.
نمایش پویایی و تعاملات با استفاده از Document Object Model (DOM).
تبادل و دستکاری داده با استفاده از XML و XSLT.
بازیابی داده‌ها بصورت غیر همروند با استفاده از XMLHttpRequest.و جاوااسکریپت برای سرهمبندی همه چیز با هم.

در واقع آژاكس ترکیبی از تکنولوژی‌های فوق است و هیچ چیز جدیدی ارائه نمی‌دهد. همه شگفتی آژاكس در معماری‌ایست که برای ساخت یک برنامه وب، با استفاده از این تکنولوژی‌ها ارائه می‌دهد.

ای جکس یک شیوه جهت طراحی و توسعه وب‌گاههابوده که جهت بالا بردن قدرت تعامل Interface سایت با کاربر و بالا بردن کیفیت عملکرد و قابلیتهای سایت مورد استفاده قرار می‌گیرد. Ajax به صورت Client Side و با به کار گیری JavaScript و CSS مورد استفاده قرار می‌گیرد. امروزه در مبحث طراحی صفحات HTML تکنولوژی Ajax عامل حیات صفحه و ارضاء کاربر در مواجهه با Interface، تلقی می‌شود [۳].

آژاكس ؛ معماری جدیدی برای وب
همانطور که اشاره شد، روش کار برنامه‌های کلاسیک وب چیزی شبیه این است: اکثر تعاملات کاربر با رابط کاربری باعث ارسال یک درخواست به سرور می‌شود. سرور پردازش‌های لازم را انجام داده و سپس یک صفحه HTML به کلاینت بازمی‌گرداند. این مدل بر اساس هدف اصلی وب، یعنی ایفای نقش یک رسانه برای ابرمتن است. اما آنچه وب را برای ابرمتن‌ها مناسب می‌کند، الزاماً آن را برای برنامه‌های نرم‌افزاری نیز مناسب نخواهد کرد. پیش از این به معایب روش کلاسیک و متداول اشاره کردیم. اکنون ببینیم Ajax چه پیشنهادی ارائه می‌دهد. قسمت‌های مهم معماری پیشنهادی آژاكس به این قرارند: رخدادهای کوچک سمت سرور: اجزای درون یک برنامه وب می‌توانند، درخواست‌های کوچکی برای سرور ارسال کنند، اطلاعات مورد نیازشان را از سرور دریافت کنند، و هر قسمت از صفحه را که لازم است بر اساس DOM به‌روز کنند، بدون اینکه تمام صفحه دوباره بارگذاری و ترسیم شود.

غیر همروند بودن: درخواست‌هایی که به سرور ارسال می‌شود، باعث مسدود شدن صفحهٔ درون مرورگر کلاینت نمی‌شوند. کاربر می‌تواند به کار با قسمت‌های دیگر برنامه ادامه دهد و هنگامی که پاسخی از سرور دریافت شد، با به‌روز کردن رابط کاربر، به کاربر اطلاع داده می‌شود.

عکس‌العمل برای هر رخدادی: تقریباً می‌توانیم برای تمام رخدادهایی که کاربر بوجود می‌آورد، با سرور ارتباط برقرار کنیم. مرورگرهای مدرن اکثر رخدادهایی را که سیستم عامل اجازه می‌دهد دریافت می‌کنند: کلیک کردن موس، حرکت موس روی شی، زدن یک کلید و غیره. هر رخدادی می‌تواند باعث ارسال یک درخواست به صورت غیر همروند برای سرور شود.

بجای اینکه مرورگر در آغاز ارتباط تنها یک صفحه HTML را بارگذاری کند، یک موتور آژاكس را نیز همراه با صفحه بارگذاری می‌کند، که به زبان جاوااسکریپت نوشته شده و معمولاً مابین فریم‌هایی در صفحه پنهان شده‌است. این موتور مسئول به‌روز کردن رابط کاربری‌ای که کاربر می‌بیند، و همچنین برقراری ارتباط با سرور در پشت پرده‌است. موتور Ajax امکان تعامل کاربر با برنامه را، مستقل از ارتباطات و نقل و انتقالات بین برنامه و سرور می‌دهد. بنابر این، کاربر دیگر شاهد یک صفحه خالی و ساعت شنی و انتظار برای انجام عملیات سمت سرور نخواهد بود.

آن دسته از فعالیت‌های کاربر که باعث یک درخواست HTTP می‌شدند، اکنون با استفاده از جاوااسکریپت موتور آژاكس را فراخوانی می‌کنند. در مورد پاسخ به آن دسته از فعالیت‌های کاربر که نیاز به ارسال درخواست به سرور ندارند (مانند اعتبار سنجی‌های ساده داده‌ها، ویرایش داده‌های درون حافظه سیستم کلاینت، و حتی هدایت کاربر به بخش‌های مختلف برنامه در برخی موارد) موتور آژاكس خود وارد عمل می‌شود. اگر موتور آژاكس برای پاسخ گویی نیاز به چیزی از سمت سرور داشته باشد، (مثلاً اطلاعاتی را از بانک اطلاعاتی بخواهد، کدهای جدیدی برای رابط کاربر لازم داشته باشد و...) بصورت غیر همروند و معمولاً در قالب XML یک درخواست به سرور ارسال می‌کند. ارسال این درخواست هیچ وقفه‌ای در کار کاربر با برنامه ایجاد نخواهد کرد [۲]. همانطور که پیش از این گفته شد، آژاكس مجموعه‌ای از چند تکنولوژی است. موتور Ajax از این تکنولوژی‌ها برای انجام وظایف مختلفی که بعهده دارد استفاده می‌کند.

پیشنهادهای ارائه شده با آژاكس
قسمت‌های مهم معماری پیشنهادی آژاكس به این قرارند [۲]:
رخدادهای کوچک سمت سرور: اجزای درون یک برنامه وب می‌توانند، درخواست‌های کوچکی برای سرور ارسال کنند، اطلاعات مورد نیازشان را از سرور دریافت کنند، و هر قسمت از صفحه را که لازم است بر اساس DOM به‌روز کنند، بدون اینکه تمام صفحه دوباره بارگذاری و ترسیم شود.
غیر همروند بودن: درخواست‌هایی که به سرور ارسال می‌شود، باعث مسدود شدن صفحهٔ درون مرورگر کلاینت نمی‌شوند. کاربر می‌تواند به کار با قسمت‌های دیگر برنامه ادامه دهد و هنگامی که پاسخی از سرور دریافت شد، با به‌روز کردن رابط کاربر، به کاربر اطلاع داده می‌شود.
عکس‌العمل برای هر رخدادی: تقریباً می‌توانیم برای تمام رخدادهایی که کاربر بوجود می‌آورد، با سرور ارتباط برقرار کنیم. مرورگرهای مدرن اکثر رخدادهایی را که سیستم عامل اجازه می‌دهد دریافت می‌کنند: کلیک کردن موس، حرکت موس روی شی، زدن یک کلید و غیره. هر رخدادی می‌تواند باعث ارسال یک درخواست به صورت غیر همروند برای سرور شود.

مشکلات آژاكس
اگرچه این روش مزایای بسیاری دارد و شکاف بین برنامه‌های رومیزی و برنامه‌های وب را بسیار کم‌تر کرده‌است، اما مشکلاتی نیز دارد که هنگام کار به این روش، باید به آن‌ها توجه کرد. یکی از مشکلاتی که در مورد آژاكس عنوان می‌شود، این مسئله‌است که این روش کاربرد کلید Back مرورگرها را مختل کرده و این بر خلاف عادت کابران در محیط وب است. البته برای حل این مسئله راه‌حل‌هایی پیشنهاد شده که این مقاله جای بحث در مورد آن‌ها نیست. مشکل دیگر آژاكس مسئله تاخیر شبکه ونگرانی در مورد زمان پاسخگویی سیستم است. مسئله تاخیر شبکه در یک برنامه بر اساس Ajax باید با دقت در نظر گرفته شود. تاخیر در بارگذاری اولیه رابط کاربر برنامه، چیزیست که معمولاً برای کاربر قابل درک نیست و باید با دادن پیغامی مناسب، کاربر را از اینکه سیستم درحال بارگذاری، یا انجام فعالیتی و برقراری ارتباطی با سرور است، آگاه کرد. مسئله دیگری که در مورد سیستم‌های بر اساس Ajax وجود دارد، استفاده آژاكس از جاوااسکریپت است و این مسئله که کاربر می‌تواند اجازه اجرای جاوااسکریپت در مرورگر خود را ندهد. پس باید پیش از شروع بارگذاری موتور آژاكس از اجازه داشتن اجرای جاوااسکریپت روی مرورگر کلاینت اطمینان پیدا کرد. البته در مورد IE نسخه ۶، به این مسئله نیز باید توجه کرد که شی XMLHttpRequest به صورت ActivX پیاده سازی شده و در نتیجه کاربر باید امکان استفاده از ActivXها را نیز به مرورگر بدهد. مسئله دیگری که باید به آن توجه داشت، این است که کدهای جاوااسکریپت برنامه را هر کسی به راحتی می‌تواند ببیند. در نتیجه بهتر است قسمت‌هایی از برنامه را که مربوط به امنیت، یا منطق پردازشی برنامه می‌شود، سمت سرور نگه داریم. به نظر می‌رسد ساخت سیستمی که ترکیب متوازنی از پردازش‌های سمت سرور و یک موتور آژاكس قوی در طرف کلاینت باشد، می‌تواند راه‌حل بسیار مناسبی باشد.
منبع:ویکی پدیا

sadegh
February 6th, 2010, 07:43
اطلاعات خودم(اگه جایی تناقض داره بگین)
آجاکس رو می شه پدیده ای در طراحی وب قرار داد که سرعت دسترسی ها را برای کاربر بیشتر می کنه و در دیگر نیاز به لود صفحات برای هر درخواستی که از طرف کاربر ندارد.که می توان در مصرف پهنای باند صرفه جویی کرد. هر چند گفته می شود باعث پایین آوردن سایت در مسئله سئو بودن سایت شود.
آجاکس بر روی کامپیوتر کاربر اجرا می شود پس مستلزم آن است که مروگر از جاوا اسکریپت پشتیبانی کند.
آجاکس از Javascript و XML و Css و HTMl به طور استاندارد تشکیل شده که میتواند موارد دیگری به آن اضافه شود.
گوگل را می توان یکی از پیشگامان استفاده از آجاکس در طراحی وب نام برد.
کتابخانه های رایگانی وجود دارد که می توان از استاندارد آنها برای طراحی استفاده کرد:
Google JavaScript ToolKit
DHTMLX LTD
Ext JS
JQury
MooTools
DynamicDrive
DhtmlGoodeis
,...
اشاره کرد.

Arashdn
February 6th, 2010, 13:43
منبعب سراغ دارید واسه یاد گیری برنامه نویسی هاش؟

persian.developer
February 6th, 2010, 14:51
منبعب سراغ دارید واسه یاد گیری برنامه نویسی هاش؟

فکر کنم واسه شروع Ajax in 10 Minutes خوب باشه البته من خودم هنوز شروع نکردم:D

afrateam
February 6th, 2010, 15:05
باعث پایین آوردن سایت در مسئله سئو بودن سایت شود.
تا جایی که من اطلاع دارم همه توضیحاتتون درست بود الا این جمله
اگه صفحات اجاکسی رو درست طراحی کنیم هیچ مشکلی از نظر سئو متوجه سایت نمیشه
میگردم یه لینک در این رابطه پیدا میکنم و میزارم
فعلا یه سرچ کوجولو زدم پیدا نکردم اون مطلب مورد نظرمو ولی خیلی منطقی دوتا روش رو توضیح داده بودن برای استفاده از اجاکس به شکلی که به سئوی سایت آسیب نرسونه

Arashdn
February 6th, 2010, 15:08
فکر کنم واسه شروع ajax in 10 minutes خوب باشه البته من خودم هنوز شروع نکردم:d
خب اینو از کجا گیر بیارم؟

persian.developer
February 6th, 2010, 15:13
خب اینو از کجا گیر بیارم؟

Ebookاش هست یه سرچ بزن پیدا میشه:Sams Teach Yourself AJAX in 10 Minutes

GOD
February 6th, 2010, 15:51
ajax با سئو اصلا رابطه خوبی نداره البته تجربه منه شاید اشتباه باشه

afrateam
February 6th, 2010, 16:10
اگه لینک هایی که قراره محتوای اجاکس لود کنه رو به شکل زیر بنویسیم از نظر سئو مشکلی پیش نمیاد


<a href="pagename.html" onclick="ajax-load('ajax-pagename.html'); return false;">

---------- Post added at 04:10 PM ---------- Previous post was at 04:05 PM ----------

آموزش: رفع مشکل SEO در Ajax به کمک PHP ! - جامعه برنامه نویس (http://www.barnamenevis.org/forum/showthread.php?p=824956)

zoghal
April 26th, 2010, 03:50
برای استفاده از ایجکس پیشنهاد می کنم . ار فریم ورک ها مخصوصا جی کوئری استفاده کنید. هر کسی سوالی داره من می تونم جوابش رو بدم در این ضمینه

tmfar
August 27th, 2010, 16:30
من می خوام شروع کنم آجاکس رو کار کنم برنامه نویسی php و html و جاوا هم بلدم یه راه سریع بگید نمی خوام هزاران صفحه کتاب بخونم

Rezash
August 27th, 2010, 16:36
من می خوام شروع کنم آجاکس رو کار کنم برنامه نویسی php و html و جاوا هم بلدم یه راه سریع بگید نمی خوام هزاران صفحه کتاب بخونم
اين مقاله سال 1385 دوست خوبم آقاي اسكندري نوشتن ، خيلي راحت توضيح دادند و با تعدادي منبع:
RightClick &bull; (http://forum.rightclick.ir/post-1550.html#p1550)
اگر هم كتاب خواستي ، معرفي كنم ، بيشتر از 50 صفحه نيست و جالب و روش هاي مختلف رو مفصل با مثال توضيح داده

packsaft
August 27th, 2010, 22:41
اين مقاله سال 1385 دوست خوبم آقاي اسكندري نوشتن ، خيلي راحت توضيح دادند و با تعدادي منبع:
RightClick &bull; (http://forum.rightclick.ir/post-1550.html#p1550)
اگر هم كتاب خواستي ، معرفي كنم ، بيشتر از 50 صفحه نيست و جالب و روش هاي مختلف رو مفصل با مثال توضيح داده

چی هست؟ چرا معرفی نمیکنید؟

Rezash
August 27th, 2010, 22:57
Bulletproof AJAX;by Jeremy Keith
ترجمه فارسيش رو هم اگه خواست : آژاكس / جركي كيت / ترجمه رضا ولي نژاد

---------- Post added at 10:57 PM ---------- Previous post was at 10:55 PM ----------

راستي در مورد صفحاتش يكم اشتباه يادم مونده بود!الان كه ورق زدم 200 صفحه بود!ولي خلاصه گفته و خيلي از صفحات كد هاي مثال هست كه تو سايتش هم هست.

packsaft
August 27th, 2010, 23:24
خب اینو از کجا گیر بیارم؟

http://www.torrentdownloads.net/download/1650940718/Teach+Yourself+Ajax+In+10+Minutes+%282006%29

shahmoradi
July 6th, 2011, 23:23
اژاکس خیلی باحاله خودم به شخصه تجربه کردم
گرچه پیچیده است ولی در کل می توان پیاده سازی کردش