-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathChapter1.txt
More file actions
61 lines (61 loc) · 12.8 KB
/
Chapter1.txt
File metadata and controls
61 lines (61 loc) · 12.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<div dir="rtl">
<h2>مقدمه</h2>
<p>در این دوره آموزشی قصد دارم با استفاده از مثال های متنوع کارکرد ها و نحوه استفاده از کتابخانه غنی Ext Js را آموزش دهم.</p>
<p>این دوره آموزشی شامل مباحث زیر می شود که هر کدام ممکن است 2 الی 3 جلسه به طول بینجامد و به مرور در وبلاگ قرار خواهد گرفت:</p>
<p>1- شروع کار با Ext Js</p>
<p>2- مفاهیم پایه</p>
<p>3- کامپوننت های اصلی Ext Js (فرم ها و انواع فیلدهای موجود در فرم ها (شامل textfield، numberfield، chebox، radio و HtmlEditor)، اعتبار سنجی فرم ها و هر آنچه در یک فرم مورد نیاز است.)</p>
<p>4- کار با داده ها</p>
<p>5- کار با گرید ها</p>
<p>6- کامپوننت های پیشرفته Extjs</p>
<p>7- کار با نمودارها</p>
<p>8- کار با تم ها و ریسپانسیو دیزاین در Ext Js</p>
<p> </p>
<p> </p>
<h2>Ext Js چیست؟</h2>
<p>زمانی که جاوااسکریپت به وجود آمد بسیاری خوشحال بودند و کارهای بسیار جالبی با آن می کردند اما به مرور زمان متوجه شدند که نگهداری و توسعه کدهای جاوااسکریپت در نرم افزارهایی که روز به روز در حال گسترش است بسیار سخت خواهد بود از این کتابخانه ها و فریم ورک هایی را برای سهولت استفاده و کاهش کدهای جاوااسکریپت تولید کردند. تعداد فریم ورک جاوااسکریپت سمت سرور و تعدادی فریم ورک سمت کلاینت ایجاد شد. Ext Js یک فریم ورک جاوااسکریپت سمت کلاینت است.</p>
<p> </p>
<h2>چرا Ext Js؟؟ (مزایای استفاده از ext js)</h2>
<h3>پشتیبانی از انواع مرورگرها</h3>
<p>شاید شما ساعت ها برای متناسب کردن عملکرد برنامه با مروگرهای مختلف (خصوصاً اینترنت اکسپلورر) کرده باشید. یا جایگیری عناصر را با استفاده از css بارها تغییر داده‌اید تا نتیجه در تمام مرورگرها تقریبا! یکسان شود. چرا شما به جای اینکه روی این مسائل تمرکز کنید روی منطق برنامه خود تمرکز نمی‌کنید؟ به نظر شما این اتلاف وقت نیست؟ زمانی که می‌توانستید در جهت بهبود و افزایش بهره وری برنامه بکنید باید صرف بالا و پایین کردن پیکسل‌های عناصر صفحه بکنید (که واقعاً کار طاقت‌فرسایی است!!!). اگر از یک فریم‌ورک جاوااسکریپتی حرفه ای مثل extjs استفاده کنید دیگر نیاز به فکر کردن به این مسائل را ندارید، خودش تمام کارها را انجام می دهد شما فقط روی منطق برنامه تمرکز کنید.</p>
<p> </p>
<h3>کامپوننت های قدرتمند</h3>
<p>Ext Js با تعداد بسیار بسیار زیادی کنترل و کامپوننت آماده ارائه شده که تمام نیاز شما به هر کامپوننتی را مرتفع می کند، این کامپوننت‌ها شامل گرید، تب پنل، درخت، انتخاب‌کننده تاریخ، انواع نمودار و ... می باشد که سرعت توسعه را بسیار بالا می‌برد.</p>
<p> </p>
<h3>انقیاد دو طرفه</h3>
<p>انقیاد دو طرفه یعنی اینکه وقتی در ظاهر برنامه مقداری تغییر کرد مدل مربوط به آن نیز به صورت اتوماتیک تغییر کند. همچنین اگر مدل شما توسط برنامه تغییر کرد در ظاهر هم آن تغییر نمایان شود.</p>
<p>مثلا شما یک فرم ویرایش باز می‌کنید، باید اطلاعات را از مدل خوانده و در فیلدهای مربوطه نمایش دهید و پس از اعمال تغییرات و ثبت اطلاعات از سوی کاربر اطلاعات را خوانده و مدل را مقداردهی کنید، Ext Js تمام این کارها را به صورت اتوماتیک برای شما انجام می‌دهد.</p>
<p> </p>
<h3>الگوی معماری برای جاوااسکریپت</h3>
<p>همانقدر که کدها به سمت کلاینت رفتند نگهداری از کدهای جاوااسکریپت سمت کلاینت سخت‌تر شد. با آمدن MVC یا (Model View Controller) و MVVM یا (Model View, View Model) به سمت کلاینت نگهداری از کدهای جاوااسکریپت به مراتب آسان تر شد. این الگوهای معماری در ادامه همین جلسه مورد بررسی قرار خواهد گرفت.</p>
<p> </p>
<h3>ساده سازی عملیات‌های پیچیده</h3>
<p>میدانید ارسال یک درخواست AJAX در جاوااسکریپت به صورتی که در همه مرورگرها اجرا شود چند خط کد می شد؟ برای بررسی پیچیدگی آن می‌توانید متد AJAX از هر فریم‌ورک جاوااسکریپتی که می خواهید را بررسی کنید. یا مثلا ساخت یک گرید در جاوااسکریپت یا امکاناتی مثل صفحه بندی، مرتب سازی، فیلتر کردن، گروه بندی، فیلدهای قابل ویرایش، قابلیت کار با صفحه کلید و ... </p>
<p> </p>
<h3>دسترسی آسان به عناصر صفحه (DOM)</h3>
<p>در جاوااسکریپت میتوانید به عناصر صفحه یا DOM elements دسترسی داشته‌باشید ولی پیچیدگیهای خاص خودش را دارد.</p>
<p> </p>
<h3>مسیریابی سمت کلاینت (routing)</h3>
<p>در نرم افزارهای وب routing عبارت است از اتصال url برنامه به منطق آن به صورتی که هر کس یک url را دید تشخیص دهد که قرار است چه نتیجه ای دریافت نماید. مسیریابی معمولا برای سمت سرور به کار می برد. در سمت کلاینت مسیریابی مختص SPAها (Single Page Application) هاست.</p>
<p> </p>
<h3>قابلیت دستیابی پذیری (accessibility)</h3>
<p>قابلیت دستیابی پذیری یعنی محتوای یک برنامه باید برای افراد کم توان از نظر بصری و کسانی که با استفاده از تکنولوژی‌های کمکی (مانند انوا screen reader ها) قابل اسفاده باشد. ساخت برنامه ای با قابلیت دستیابی پذیری بالا بسیار سخت است.</p>
<p>در امریکا اگر برنامه ای نوشته شود که مورد استفاده ادارات ایالتی یا فدرال قرار گیرد باید حتما قابلیت دستیابی پذیری داشته باشد. تعداد بسیار کمی فریم‌ورک جاوااسکریپتی این قابلیت را در اختیار شما قرار می‌دهند.</p>
<p>کنسرسیوم وب جهان گستر (W3C) یک مشخصات تکنیکی تحت عنوان WAI-ARIA یا (Web Accessibility Initiative - Accessible Rich Internet Applications) ایجاد کرده است. این مشخصات راههایی که باعث می شود یک صفحه وب برای افراد ناتوان قابلیت استفاده را داشته باشد مشخص کرده است. Ext JS به صورت بسیار خوبی از این ویژگی ها و مشخصات پیروی کرده است و تمام کنترل ها و ویجت های Ext JS قابلیت دستیابی پذیری دارند و شما نیاز به هیچ کار اضافه ای ندارید.</p>
<p> </p>
<h2>معرفی اجمالی Ext JS</h2>
<p>Ext JS یک فریم‌ورک است که به تنهایی می توانید تمام UI یک برنامه بسیار بزرگ را پیاده کنید و به هیچ چیز دیگری نیاز نداشته باشید. تمام قابلیت های ذکر شده در بالا را برای شما فراهم می آورد. مستندسازی بسیار بسیار عالی و قدرتمند با قابلیت دانلود که می‌توانید اطلاعات تمام API های فریم‌ورک را در آن مشاهده نمایید. Ext JS در ابتدا به عنوان یک کتابخانه الحاقی به YUI توسط Jack Slocum ایجاد شد و اکنون محصولی از Sencha Inc است.</p>
<p>در Ext JS شما تقریبا تمام کدهایتان را در جاوااسکریپت می‌نویسید و خیلی نیازی به HTML ندارید. Ext JS با تعداد بسیار زیادی کامپوننت اراپه می‌شود و زمان بسیار بسیار زیادی را برای شما صرفه‌جویی می کند. ما در این سری آموزشی از Ext JS Version 6 استفاده می کنیم که در حال حاضر آخرین نسخه از این فریم‌ورک است. مهمترین تغییری که در Ext JS 6 رخ داده این است که دو محصول Sencha با هم ادغام شده اند: Ext JS و Sencha Touch. در ضمن Ext JS 6 با یک کامپایلر جدید SAAS با نام Fushion و بهبودهایی در نمودارهای 3D و ... آممده است.</p>
<p>Sencha Touch محصولی از Sencha است که برای ساخت نرم‌افزارهای تحت وب که روی دستگاه‌های موبایل و تبلت نمایش داده می‌شود استفاده می‌شد. Ext JS 4 و Ext JS 5 برای ایجاد نرم‌افزارهای تحت وب در مورورگرهای دسکتاپی استفاده می شد اما می توان برای نرم افزارهای قابل نمایش در موبایل و تپلت هم از آنها استفاده کرد با این وجود از امکانات مربوط به touch صفحه و بهره وری بهینه از شتاب دهی سخت افزاری موجود در مویابل ها بی بهره خواهید بود بنابراین بهتر بود برای نوشتن ظاهر موبايل نرم‌افزار از Sencha Touch استفاده کنید.</p>
<p>قبلاْ Ext JS و Sencha Touch دو نرم افزار جداگانه بودند که کدهای هسته یکسانی داشتند ولی از جهات مختلف با هم متفاوت بودند ولی در حال حاضر این دو با هم ادغام شده اند و تحت عنوان Ext JS 6 و در قالب ۲ تول‌کیت به نام‌های classic برای مرورگرهای دسکتاپ و modern برای مرورگرهای موبایل منتشر شده که کار را برای نوشتن برنامه ای متناسب با همه مرورگرهای دسکتتاپ و موبایل و تبلت آسان منوده است. هر گاه کاربری با موبایل نرم‌افزار را مشاهده کند با ظاهری که توسط تول کیت modern ایجاد شده مواجه می شود و هرگاه با مرورگر دسکتاپی به برنامه مراجعه کند به ظاهر ایجاد شده توسط تول‌کیت classic منتقل خواهد شد. </p>
<h4><span style="background-color: #cc99ff;">نکته:</span></h4>
<p>toolkit ها مجموعه عناصر بصری (کنترل ها و کامپوننت ها) هستند که متناسب با مرورگر بهینه شده اند.</p>
<p>بنابراین در Ext JS 6 شما می توانید تعداد زیادی کد یکسان داشته و فقط گاهی باید یک سری view را به صورت مجزا برای موبایل و دسکتاپ بنویسید.</p>
<p> </p>
<blockquote>
<p>ادامه موضوعات درباره دانلود Ext JS 6 و ایجاد اولین نرم افزار Ext JS توسط Sencha CMD را در جلسه آینده خواهم گفت.</p>
</blockquote>
<p> </p>
<h4><span style="background-color: #cc99ff;">پ ن:</span></h4>
<p>Sencha CMD ابزاری است که برای راحت تر کردن کار با فریم‌ورک Ext JS توسط توسعه دهندگانش ایجاد شده و بسیاری از کارهای متداول را راحت تر و سریع تر می‌کند. این نرم افزار هم در جلسه آینده بیشتر مورد بررسی قرار می‌گیرد. </p>
</div>