آموزش ایجکس (AJAX)

دسته بندی: آموزش طراحی وب

آموزش ایجکس

آنچه در این صفحه می خوانید:

معرفی ایجکس (AJAX)

Asynchronous JavaScript And XML یا به اختصار Ajax مجموعه ای از تکنیک های توسعه وب با استفاده از بسیاری از فناوری های وب در سمت کلاینت برای ایجاد برنامه های وب ناهمزمان است. با ایجکس، برنامه های وب می توانند داده ها را از سرور یا پایگاه داده به طور همزمان (در پس زمینه) و بدون دخالت در نمایش صفحه و رفتار صفحه موجود ارسال و بازیابی کنند. ایجکس با جدا کردن لایه تعویض داده از لایه نمایش، به سایت و برنامه های وب اجازه می دهد تا بدون نیاز به بارگیری مجدد کل صفحه، محتوای آن را به صورت پویا تغییر دهند. در واقع، روش تبادل داده ها با سرور و به روز رسانی قسمت های صفحه وب بدون بارگذاری مجدد کل صفحه می باشد. در عمل، پیاده سازی های مدرن معمولاً از جی سان (JSON) به جای اکس ام ال (XML) استفاده می کنند.

ایجکس یک فناوری واحد نیست بلکه یک گروه از فناوری است. اچ تی ام ال (HTML) و سی اس اس (CSS) را می توان در ترکیب برای علامت گذاری و سبک کردن اطلاعات استفاده کرد. سپس صفحه وب می تواند توسط جاوااسکریپت تغییر یابد تا به صورت پویا نمایش داده شود و به کاربر اجازه دهد تا با اطلاعات جدید ارتباط برقرار کند. شی داخلی XMLHttpRequest یا از سال 2017 عملکرد جدید "()fetch" در JavaScript، معمولاً برای اجرای Ajax در صفحات وب استفاده می شود که به وب سایت ها اجازه می دهد تا محتوا را بر روی صفحه بارگذاری کنند بدون اینکه صفحه را رفرش کنند. ایجکس فناوری جدید یا زبان برنامه نویسی نیست، فقط فناوری های موجود است که به روش های جدید مورد استفاده قرار می گیرد.

تاریخچه ایجکس (AJAX)

در اوایل اواسط دهه 1990، بیشتر وب سایت ها کامل مبتنی بر صفحات HTML بودند. هر اقدام کاربر نیاز به بارگیری صفحه کامل از سرور دارد. این روند، همانطور که توسط تجربه کاربر منعکس شده است ناکارآمد است: تمام محتوای صفحه ناپدید شدند، سپس صفحه جدید ظاهر شد. هر بار مرورگر به دلیل تغییر جزئی، بارگیری مجدد صفحه، مجبور می شد مجدداً ارسال شود، حتی اگر برخی از اطلاعات تغییر کرده بودند. این بار اضافی را روی سرور قرار داده و پهنای باند را به عنوان عامل محدود کننده در عملکرد تبدیل کرده است.

در سال 1996، تگ iframe توسط Internet Explorer معرفی شد. مانند عنصر شی، می تواند محتوای را بصورت غیر همزمان بارگیری کند. در سال 1998، تیم مایکروسافت Outlook Web Access مفهوم پشت شی برنامه نویسی XMLHttpRequest را توسعه داد. به عنوان XMLHTTP در نسخه دوم كتابخانه MSXML ظاهر شد كه در مارس 1999 با Internet Explorer 5.0 ارسال شد.

عملکرد کنترل XMLHTTP ActiveX در اینترنت اکسپلورر 5 بعداً توسط مرورگرهای موزیلا، سافاری، اپرا و سایر موارد به عنوان شی JavaScript XMLHttpRequest اجرا شد. مایکروسافت مدل بومی XMLHttpRequest را از طریق Internet Explorer 7 اتخاذ کرده است. نسخه ActiveX هنوز در اینترنت اکسپلورر پشتیبانی می شود، اما در Microsoft Edge پشتیبانی نمی شود. ابزار این درخواست های پس زمینه HTTP و فناوری های وب ناهمزمان نسبتاً مبهم است تا اینکه در برنامه های آنلاین گسترده در مقیاس بزرگ مانند Outlook Web Access و Oddpost ظاهر شود.

گوگل از Ajax با Gmail (2004) و Google Maps (2005) استفاده گسترده ای به صورت سازگار با استانداردها و مرورگرهای ایجکس انجام داد. در اکتبر 2004، انتشار بتا عمومی Kayak.com جزو اولین استفاده های گسترده در تجارت الکترونیکی از آنچه توسعه دهندگان آنها در آن زمان "the xml http thing" نامیده می شدند بود. این افزایش علاقه در AJAX در بین برنامه نویسان برنامه وب است. در 5 آوریل 2006، کنسرسیوم جهانی وب (W3C) اولین تلاش برای ایجاد XMLHttpRequest را با هدف ایجاد استاندارد وب رسمی منتشر کرد. آخرین پیش نویس شی XMLHttpRequest در 6 اکتبر 2016 منتشر شد.

تکنولوژی های ایجکس (AJAX)

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

  • HTML (یا XHTML) و CSS برای ارائه
  • Document Object Model (DOM) برای نمایش پویا و تعامل با داده ها
  • JSON یا XML برای تبادل داده و XSLT برای دستکاری آن
  • هدف XMLHttpRequest برای ارتباطات ناهمزمان است
  • جاوا اسکریپت برای جمع آوری این فناوری ها

از آن زمان، پیشرفت های بسیاری در فناوری های مورد استفاده در برنامه Ajax و در تعریف اصطلاح Ajax به وجود آمده است. XML دیگر برای تبادل داده دیگر لازم نیست و بنابراین، XSLT دیگر برای دستکاری داده ها لازم نیست. نوت بوک جاوا اسکریپت (JSON) اغلب به عنوان قالب جایگزین برای تبادل داده استفاده می شود، اگرچه می توان از قالب های دیگر مانند HTML از پیش ساخته یا متن ساده نیز استفاده کرد. انواع کتابخانه های محبوب JavaScript، از جمله جی کوئری، شامل موارد انتزاعی برای کمک به اجرای درخواست های Ajax هستند.

ویژگی های ایجکس (AJAX)

  • مستقل از فناوری سرور.
  • عملکرد صفحه وب را افزایش دهید.
  • پشتیبانی از اتصال داده زنده
  • پشتیبانی از کنترل View Data
  • پشتیبانی از ارائه الگوهای سمت کلاینت
  • رابط کاربری غنی و رسپانسیو
  • کاهش مصرف منابع سرور
  • بدون نیاز به فشار دادن دکمه ارسال و بارگذاری مجدد کامل وب سایت.
  • فقط نیازی به بارگذاری مجدد کل صفحه فقط بخشی از صفحه بارگیری مجدد می شود که برای بارگیری مجدد لازم است.
  • جدا از به دست آوردن هدف XMLHTTP، تمام پردازش ها برای همه انواع مرورگر یکسان است، زیرا از JavaScript استفاده می شود.
  • با استفاده از ایجکس برنامه های وب سریعتر و تعاملی ایجاد کنید.

ایجکس (AJAX) چگونه کار می کند؟

طبق گفته Cascarano، جاوااسکریپت و XML با هم ترکیب می شوند تا با استفاده از شی XMLHttpRequest، بروزرسانی ناهمزمان اتفاق بیفتد. هنگامی که کاربر از صفحه وب که برای استفاده از AJAX طراحی شده بازدید می کند و رویداد پیش بینی شده رخ می دهد (کاربر صفحه را باز می کند، روی دکمه کلیک می کند، فرم را پر می کند و غیره.) JavaScript شی XMLHttpRequest را ایجاد می کند، که سپس داده ها را در XML منتقل می کند. XMLHttpRequest درخواستی برای داده های صفحه به روز شده به سرور وب ارسال می کند، سرور درخواست را پردازش می کند، پاسخ توسط سرور ایجاد می شود و به مرورگر ارسال می شود، سپس از JavaScript برای پردازش پاسخ و نمایش آن بر روی صفحه به عنوان محتوای به روز شده استفاده می شود.

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

مثال ایجکس (AJAX)

 <!DOCTYPE html>
<html>
<body>

<div id="demo"> <h2>Let AJAX change this text</h2> <button type="button" onclick="loadDoc()">Change Content</button> </div>

</body> </html>

صفحه HTML شامل بخش <div> و یک <button> است. از بخش <div> برای نمایش اطلاعات از سرور استفاده می شود. <button> یک تابع (در صورت کلیک) فراخوانی می کند. این عملکرد داده ها را از سرور وب درخواست می کند و آن را نمایش می دهد:

()Function loadDoc

function loadDoc() {
  var xhttp = new XMLHttpRequest();
  xhttp.onreadystatechange = function() {
    if (this.readyState == 4 && this.status == 200) {
     document.getElementById("demo").innerHTML = this.responseText;
    }
  };
  xhttp.open("GET", "ajax_info.txt", true);
  xhttp.send();
}

آیا این نوشته را دوست داشتید؟
packtpub-html-css-and-javascript-for-beginners-a-web-design-course

دوره طراحی وب با HTML و CSS و Javascript برای مبتدیان


این دوره تمامی مفاهیم طراحی وب را پوشش می دهد. از سینتکس های پایه گرفته تا تگ های رایج مورد استفاده برای ایجاد محتوای وب و چگونگی نوشتن کدهای HTML. شم...

1398/08/13 20384 بازدید
linkedin-learning-asp-net-linkedin-learning

یادگیری ASP.NET


در این دوره با چارچوب ASP.NET، ابزارهای این چارچوب برای مدیریت داده‌ها، ایجاد سرویس‌های RESTful و ایجاد اتصالات بلادرنگ وب، ساخت محتوای پویا وب با ASP...

1398/07/26 1534 بازدید زیرنویس دارد
packtpub-a-quick-start-guide-to-learn-jquery-fundamentals

یک شروع سریع برای یادگیری مبانی جی کوئری


در این دوره ساختار کد جی کوئری را به خوبی یاد می گیرید و نحوه استفاده از کد های جی کوئری برای جلوه دادن به عناصر صفحه ی وب را می آموزید و می توانید ب...

1398/07/05 719 بازدید
teamtreehouse-ajax-basics-course

دوره مبانی AJAX 


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

1397/08/30 1288 بازدید
packtpub-ajax-api-exercises-and-a-javascript-trivia-web-application-video

آموزش تمرینات AJAX API و اپلیکیشن وب جاوااسکریپت


یا تا به حال با چالش های درک و ایجاد یک برنامه وب مواجه شده اید؟ از کجا شروع کنم؟ آیا می خواهید بر این مشکلات غلبه کنید؟ این دوره با تمرین های سرگرم ک...

1397/08/16 1061 بازدید
packtpub-an-exercise-on-the-json-server-with-an-ajax-practice-application-video

آموزش راه اندازی و کار با JSON و AJAX


آیا شما به دنبال یک راه آسان برای راه اندازی سرور JSON هستید؟  این دوره برای راه اندازی و یادگیری JSON و AJAX طراحی شده است. در این دوره با پایگاه داد...

1397/08/15 1146 بازدید
packtpub-learn-jquery-ajax-in-1-hour-video

آموزش jQuery AJAX در 1 ساعت


اگر شما در حال جستجو برای یک اپلیکیشن توسعه AJAX هستید و نیاز به اعمال AJAX به اپلیکیشن های وب خود دارید، این دوره برای شما است. AJAX می تواند داده ها...

1397/08/03 1157 بازدید
packtpub-a-complete-json-ajax-api-course-beginner-to-professional-video

آموزش کامل JSON AJAX API - از مبتدی تا پیشرفته


JSON فرمت ترجیحی برای داده هایی است که بین زبان های برنامه نویسی منتقل می شوند. خواندن، ایجاد و کار با آن آسان است. در این دوره، شما درباره JSON دربار...

1397/08/01 2073 بازدید
packtpub-ajax-api-exercise-crypto-currency-data-application-video

آموزش ایجاد اپلیکیشن Cryptocurrenciy با AJAX API


این دوره کامل برای مبتدیان است تا بیشتر با اتصال به endpoints وب، خطاهای CORS، گزینه های مختلف برای درخواست HTTP، مدیریت داده ها و تکرار از طریق آن بر...

1397/07/19 787 بازدید
packtpub-an-infinite-scroll-project-using-ajax-mysql-api-php-and-jquery-video

آموزش استفاده از تکنیک Infinite scrolling در وب سایت ها


تکنیک Infinite scrolling در طراحی وب کاربرد دارد که هم زمان با اسکرول کردن صفحه توسط کاربر محتوا را بارگذاری می کند. این تکنیک محبوب در بسیاری از وب س...

1397/07/19 1994 بازدید