diff --git a/docs/frontend/images/layout.png b/docs/frontend/images/layout.png new file mode 100644 index 00000000..3120cfe6 Binary files /dev/null and b/docs/frontend/images/layout.png differ diff --git a/docs/frontend/images/sass.png b/docs/frontend/images/sass.png new file mode 100644 index 00000000..a4c1bed0 Binary files /dev/null and b/docs/frontend/images/sass.png differ diff --git a/docs/frontend/phase01-js-fundamental.md b/docs/frontend/phase01-js-fundamental.md new file mode 100644 index 00000000..cfe53c96 --- /dev/null +++ b/docs/frontend/phase01-js-fundamental.md @@ -0,0 +1,337 @@ +--- +title: Js Fundamental +description: محتوایی که لازم هست همه بدونن +tags: [Js-Fundamental] +--- + +## مقدمه + +در این فاز قصد داریم قبل از شروع پروژه با برخی نکات ساده اما مهم آشنا شویم +که در ادامۀ کار به کمک ما خواهند آمد. + +- چرا برای تعریف متغیر میتوان از سه عبارت + `var` + و + `let` + و + `const` + استفاده کرد؟ +- تفاوت + Function + با + Arrow Function + چیست؟ +- مفهوم و کاربرد + `this` + چیست؟ +- Event Loop + چیست؟ + +## یادگیری + +### متغیرها + +قبل از سال 2015 میلادی، برای تعریف متغیر در +JavaScript +تنها میتوانستیم از +`var` +استفاده کنیم. +اما با معرفی +ES6 +عبارتهای +`let` و `const` +نیز به این زبان اضافه شدند که در اینجا توضیحات مختصری در مورد هر کدام ارائه میکنیم. + +#### var + +زمانی که یک متغیر را با عبارت +`var` +تعریف میکنید، +آن متغیر در +Global Scope +یا نزدیکترین +Function Scope +تعریف میشود. + +به عنون مثال خروجی کد زیر: + +```javascript +function defineAndPrintName() { + if (true) { + var name = 'Codestar'; + console.log(`inner scope -> name: ${name}`); + } + + console.log(`outer scope -> name: ${name}`); +} + +defineAndPrintName(); +``` + +به شکل زیر خواهد بود: + +```text +inner scope -> name: Codestar +outer scope -> name: Codestar +``` + +چرا که متغیر +`name` +داخل اسکوپِ تابعِ +`defineAndPrintName` +قرار میگیرد. + +لازم به ذکر است که +Scope +ها در +JavaScript +با آکلاد مشخص میشوند +بنابراین نیازی به +`if (true)` +نداریم. + +#### let + +برخلاف +`var` +، زمانی که از +`let` +برای تعریف یک متغیر استفاده کنیم، +آن متغیر در +Scope +فعلی محدود میشود. + +بهعنوان مثال خروجی کد زیر: + +```javascript +function defineAndPrintName() { + { + let name = 'Codestar'; + console.log(`inner scope -> name: ${name}`); + } + + console.log(`outer scope -> name: ${name}`); +} + +defineAndPrintName(); +``` + +به شکل زیر خواهد بود: + +```text +inner scope -> name: Codestar +ReferenceError: name is not defined +``` + +#### const + +`const` +دقیقاً مانند +`let` +عمل میکند با این تفاوت که فقط یک بار میتوان آن را مقداردهی کرد. +زمانی که احتیاج داشته باشیم مقداری را ذخیره کنیم که هیچوقت نباید تغییر کند، +استفاده از +`const` +باعث جلوگیری از خطاهای احتمالی میشود؛ +همچنین زمانی که شخص دیگری کد را میخواند، +با دیدن +`const` +مطمئن میشود که مقدار آن تغییر نخواهد کرد. +ما پیشنهاد میکنیم همیشه به صورت پیشفرض برای تعریف متغیرها از +`const` +استفاده کنید +و تنها در صورت نیاز به +`let` +مراجعه کنید. + +برای آشنایی بیشتر با این مفاهیم میتوانید از لینکهای زیر استفاده کنید: + +- [var vs let vs const in JavaScript](https://ui.dev/var-let-const/) +- [Medium - Difference Between Var, Let and Const in ES6](https://medium.com/infancyit/difference-between-var-let-and-const-in-es6-16a08d74b8b2) +- [freeCodeCamp - Var, Let, and Const – What's the Difference?](https://www.freecodecamp.org/news/var-let-and-const-whats-the-difference/) + +:::tip + +برای آشنایی بهتر با تفاوت این سه نوع متغییر میتوانید ویدئوی زیر را مشاهده کنید: + +[JavaScript Let vs Var vs Constant](https://www.youtube.com/watch?v=XgSjoHgy3Rk) +::: + +### Regular Function vs Arrow Function + +در +JavaScript +به دو شکل میتوان یک تابع را تعریف کرد: + +```javascript +function sayHello(name) { + console.log(`hello, ${name}!`); +} + +// or + +const sayHello = (name) => { + console.log(`hello, ${name}!`); +}; +``` + +که به نوع اول +Regular Function +و به نوع دوم +Arrow Function +گفته میشود. +در اینجا به تفاوت این دو روش میپردازدیم. + +#### this + +زمانی که از +Regular Function +استفاده میکنیم مقدار +`this` +با توجه به مکانی که تابع از آنجا صدا زده میشود، متفاوت است. +اما اگر از +Arrow Function +استفاده کنیم، این مقدار همواره برابر با شیئی است که تابع در آن تعریف شده. + +```javascript +const regularFunctionWrapper = { + whatIsThis: function () { + console.log(this); // regularFunctionWrapper + }, +}; + +const arrowFunctionWrapper = { + whatIsThis: () => { + console.log(this); // globalThis + }, +}; + +regularFunctionWrapper.whatIsThis(); +arrowFunctionWrapper.whatIsThis(); +``` + +#### Constructor + +قبل از اینکه کلاسها به +JavaScript +بیایند، از +Regular Function +بهعنوان +Constructor +استفاده میشد: + +```javascript +function Circle(radius) { + this.radius = radius; + + this.printArea = function () { + console.log('area', Math.PI * Math.pow(this.radius, 2)); + }; +} + +const small = new Circle(10); +const large = new Circle(100); + +small.printArea(); +large.printArea(); +``` + +#### arguments & args + +در +Regular Function +یک کلیدواژه به نام +arguments +وجود دارد که درواقع آرایهای از پارامترهای ورودی میباشد؛ +در +Arrow Function +هم میتوانیم به این پارامترها دسترسی داشته باشیم اما باید صراحتاً در ورودیهای تابع به آن اشاره کنیم: + +```javascript +function regularFunctionSum() { + let result = 0; + + for (const n of arguments) { + if (!isNaN(n)) result += n; + } + + return result; +} + +const arrowFunctionSum = (...args) => { + let result = 0; + + for (const n of args) { + if (!isNaN(n)) result += n; + } + + return result; +}; + +console.log('Regular Function', regularFunctionSum(4, 8, 15, 16, 23, 42)); // 108 +console.log('Arrow Function', arrowFunctionSum(4, 8, 15, 16, 23, 42)); // 108 +``` + +#### return + +در +Arrow Function +اگر بدنۀ تابع فقط شامل یک +Expression +باشد، میتوان آن را بدونِ استفاده از آکلاد و +return +نوشت: + +```javascript +const rand = (min, max) => Math.floor(Math.random() * (max - min) + min); + +console.log(rand(4, 42)); +``` + +برای آشنایی بیشتر با این مفاهیم میتوانید از لینکهای زیر استفاده کنید: + +- [5 Differences Between Arrow and Regular Functions](https://dmitripavlutin.com/differences-between-arrow-and-regular-functions/) +- [freeCodeCamp - When (and why) you should use ES6 arrow functions — and when you shouldn’t](https://www.freecodecamp.org/news/when-and-why-you-should-use-es6-arrow-functions-and-when-you-shouldnt-3d851d7f0b26/) + +### Event Loop + +حلقه رویداد، جزء اصلی موتور جاوا اسکریپت است که وظایف مختلف را به ترتیب صحیح و بدون ایجاد وقفه در رابط کاربری، مدیریت +میکند. این حلقه، نقش یک ناظر را ایفا میکند و صف وظایف را که شامل رویدادها، درخواستهای شبکه و کدهای جاوا اسکریپت است، +رصد میکند. + +وظایف موجود در صف به دو دسته اصلی تقسیم میشوند: + +- **1. وظایف ماکرو:** این وظایف شامل کدهای اصلی جاوا اسکریپت مانند کلیک کاربر، اجرای اسکریپتها و پاسخ به درخواستهای + DOM + است. وظایف ماکرو به ترتیب دریافت در صف قرار میگیرند و تا زمانی که به طور کامل اجرا نشوند، سایر وظایف منتظر میمانند. + +- **2. وظایف میکرو:** وظایف میکرو، وظایف کماهمیتتری هستند که به طور همزمان با وظایف ماکرو انجام میشوند. وعدهها + (promises) + و + callbacks + مربوط به رویدادهای + async/await + نمونههایی از وظایف میکرو هستند. این وظایف نقش مهمی در عملکرد و پاسخگویی درست رابط کاربری ایفا میکنند. + +حلقه رویداد به طور مداوم در حال گردش است و وظایف را از صف به ترتیب زیر پردازش میکند: + +- بررسی صف وظایف ماکرو: اگر وظیفهای در صف وجود داشته باشد، آن را اجرا میکند. +- پردازش وظایف میکرو: تا زمانی که صف ماکرو خالی شود، به پردازش وظایف میکرو میپردازد. +- تکرار فرآیند: مراحل 1 و 2 را به طور مداوم تکرار میکند تا زمانی که صف وظایف خالی شود. + +درک حلقه رویداد برای نوشتن کد جاوا اسکریپت کارآمد و بدون انسداد رابط کاربری ضروری است. با تسلط بر این مفهوم، میتوانید +برنامههای تعاملی و پاسخگو بسازید که تجربهای کاربری قابلقبولی را ارائه میکنند. + +برای آشنایی بیشتر با این مفاهیم میتوانید از لینکهای زیر استفاده کنید: + +- [The event loop](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Event_loop) +- [What is an event loop in JavaScript](https://www.geeksforgeeks.org/what-is-an-event-loop-in-javascript/) + +:::tip +برای آشنایی بهتر با +Event Loop +پیشنهاد میکنیم ویدئوی زیر را مشاهده کنید: + +[In The Loop](https://www.youtube.com/watch?v=cCOL7MC4Pl0) + +::: diff --git a/docs/frontend/phase01-sandbox.md b/docs/frontend/phase01-sandbox.md deleted file mode 100644 index 91f55dc8..00000000 --- a/docs/frontend/phase01-sandbox.md +++ /dev/null @@ -1,446 +0,0 @@ ---- -title: Sandbox -description: When I was a kid, my mom used to just throw me into a pile of broken glass! -tags: [Sandbox] ---- - -:::info این فاز، یکی از فازهای `Sandbox` است. - -به فازهایی `Sandbox` میگوییم که به طور مستقیم به پروژه مربوط نمیشوند -و در کارگاهی که برای آنها برگزار میشود، مدرس در یک محیط ایزوله به تدریس میپردازد. -البته این به آن معنا نیست که در این فازها نکات کماهمیتی گفته میشود؛ -بلکه در آنها نکات مهمی تعبیه شده که در فازهای دیگر قابل بیان نبودند. - -::: - -## مقدمه - -در این فاز قصد داریم قبل از شروع پروژه با برخی نکات ساده اما مهم آشنا شویم -که در ادامۀ کار به کمک ما خواهند آمد. - -- چرا برای تعریف متغیر میتوان از سه عبارت `var` و `let` و `const` استفاده کرد؟ -- تفاوت Function با Arrow Function چیست؟ -- مفهوم و کاربرد `this` چیست؟ -- صفت `type` در تگ `script` چیست؟ -- چطور میتوان از کدی که دیگران نوشتهاند استفاده کرد؟ -- برای افزایش خوانایی کد چه کارهایی میتوان انجام داد؟ - ---- - -## یادگیری - -### متغیرها - -قبل از سال 2015 میلادی، برای تعریف متغیر در JavaScript تنها میتوانستیم از `var` استفاده کنیم. -اما با معرفی ES6 عبارتهای `let` و `const` نیز به این زبان اضافه شدند که در اینجا توضیحات مختصری در مورد هر کدام ارائه میکنیم. - -#### var - -زمانی که یک متغیر را با عبارت `var` تعریف میکنید، -آن متغیر در Global Scope یا نزدیکترین Function Scope تعریف میشود. - -به عنون مثال خروجی کد زیر: - -```javascript -function defineAndPrintName() { - if (true) { - var name = 'Bijan'; - console.log(`inner scope -> name: ${name}`); - } - - console.log(`outer scope -> name: ${name}`); -} - -defineAndPrintName(); -``` - -به شکل زیر خواهد بود: - -```text -inner scope -> name: Bijan -outer scope -> name: Bijan -``` - -چرا که متغیر `name` داخل اسکوپِ تابعِ `defineAndPrintName` قرار میگیرد. - -لازم به ذکر است که Scopeها در JavaScript با آکلاد مشخص میشوند -بنابراین نیازی به `if (true)` نداریم. - -#### let - -برخلاف `var`، زمانی که از `let` برای تعریف یک متغیر استفاده کنیم، -آن متغیر در Scope فعلی محدود میشود. - -بهعنوان مثال خروجی کد زیر: - -```javascript -function defineAndPrintName() { - { - let name = 'Bijan'; - console.log(`inner scope -> name: ${name}`); - } - - console.log(`outer scope -> name: ${name}`); -} - -defineAndPrintName(); -``` - -به شکل زیر خواهد بود: - -```text -inner scope -> name: Bijan -ReferenceError: name is not defined -``` - -#### const - -`const` -دقیقاً مانند `let` عمل میکند با این تفاوت که فقط یک بار میتوان آن را مقداردهی کرد. -زمانی که احتیاج داشته باشیم مقداری را ذخیره کنیم که هیچوقت نباید تغییر کند، -استفاده از `const` باعث جلوگیری از خطاهای احتمالی میشود؛ -همچنین زمانی که شخص دیگری کد را میخواند، -با دیدن `const` مطمئن میشود که مقدار آن تغییر نخواهد کرد. -ما پیشنهاد میکنیم همیشه به صورت پیشفرض برای تعریف متغیرها از `const` استفاده کنید -و تنها در صورت نیاز به `let` مراجعه کنید. - -برای آشنایی بیشتر با این مفاهیم میتوانید از لینکهای زیر استفاده کنید: - -- [var vs let vs const in JavaScript](https://ui.dev/var-let-const/) -- [Medium - Difference Between Var, Let and Const in ES6](https://medium.com/infancyit/difference-between-var-let-and-const-in-es6-16a08d74b8b2) -- [freeCodeCamp - Var, Let, and Const – What's the Difference?](https://www.freecodecamp.org/news/var-let-and-const-whats-the-difference/) - ---- - -### Regular Function vs Arrow Function - -در JavaScript به دو شکل میتوان یک تابع را تعریف کرد: - -```javascript -function sayHello(name) { - console.log(`hello, ${name}!`); -} - -// or - -const sayHello = (name) => { - console.log(`hello, ${name}!`); -}; -``` - -که به نوع اول Regular Function و به نوع دوم Arrow Function گفته میشود. -در اینجا به تفاوت این دو روش میپردازدیم. - -#### this - -زمانی که از Regular Function استفاده میکنیم مقدار `this` با توجه به مکانی که تابع از آنجا صدا زده میشود، متفاوت است. -اما اگر از Arrow Function استفاده کنیم، این مقدار همواره برابر با شیئی است که تابع در آن تعریف شده. - -```javascript -const regularFunctionWrapper = { - whatIsThis: function () { - console.log(this); // regularFunctionWrapper - }, -}; - -const arrowFunctionWrapper = { - whatIsThis: () => { - console.log(this); // globalThis - }, -}; - -regularFunctionWrapper.whatIsThis(); -arrowFunctionWrapper.whatIsThis(); -``` - -#### Constructor - -قبل از اینکه کلاسها به JavaScript بیایند، از Regular Function بهعنوان Constructor استفاده میشد: - -```javascript -function Circle(radius) { - this.radius = radius; - - this.printArea = function () { - console.log('area', Math.PI * Math.pow(this.radius, 2)); - }; -} - -const small = new Circle(10); -const large = new Circle(100); - -small.printArea(); -large.printArea(); -``` - -#### arguments & args - -در Regular Function یک کلیدواژه به نام arguments وجود دارد که درواقع آرایهای از پارامترهای ورودی میباشد؛ -در Arrow Function هم میتوانیم به این پارامترها دسترسی داشته باشیم اما باید صراحتاً در ورودیهای تابع به آن اشاره کنیم: - -```javascript -function regularFunctionSum() { - let result = 0; - - for (const n of arguments) { - if (!isNaN(n)) result += n; - } - - return result; -} - -const arrowFunctionSum = (...args) => { - let result = 0; - - for (const n of args) { - if (!isNaN(n)) result += n; - } - - return result; -}; - -console.log('Regular Function', regularFunctionSum(4, 8, 15, 16, 23, 42)); // 108 -console.log('Arrow Function', arrowFunctionSum(4, 8, 15, 16, 23, 42)); // 108 -``` - -#### return - -در Arrow Function اگر بدنۀ تابع فقط شامل یک Expression باشد، میتوان آن را بدونِ استفاده از آکلاد و return نوشت: - -```javascript -const rand = (min, max) => Math.floor(Math.random() * (max - min) + min); - -console.log(rand(4, 42)); -``` - -برای آشنایی بیشتر با این مفاهیم میتوانید از لینکهای زیر استفاده کنید: - -- [5 Differences Between Arrow and Regular Functions](https://dmitripavlutin.com/differences-between-arrow-and-regular-functions/) -- [freeCodeCamp - When (and why) you should use ES6 arrow functions — and when you shouldn’t](https://www.freecodecamp.org/news/when-and-why-you-should-use-es6-arrow-functions-and-when-you-shouldnt-3d851d7f0b26/) - ---- - -### Modules - -#### type - -یکی از صفاتی که میتوان به تگ `script` اضافه کرد، `type` است؛ -این صفت همانطور که از اسمش پیداست، مشخص میکند که مرورگر چگونه با کد شما برخورد کند. -مقادیر متنوعی را میتوان برای `type` در نظر گرفت اما در اینجا فقط به `module` اشاره میکنیم. - -```html - -``` - -#### مزایا - -یکی از بزرگترین مزایای استفاده از `module` این است که میتوانید کد خود را به چند فایل تقسیم کنید -و هر فایل را برای کار خاصی در نظر بگیرید. -بهعنوان مثال فرض کنید بخواهیم دو کلاس با نامهای `Circle` و `Square` داشته باشیم، -اشیائی با آنها بسازیم و در نهایت محیط و مساحت هر کدام را محاسبه کنیم؛ -از سه راه میتوانیم به هدف خود برسیم: - -1. قرار دادن تمام کدها در یک فایل -1. قرار دادن کد هر قسمت در یک فایل جدا و استفاده از سه تگ `script` در HTML -1. قرار دادن کد هر قسمت در یک فایل جدا و استفاده از `module` - -واضح است که روش اول خوانایی کد را بهشدت پایین میآورد -و اگر در آینده بخواهیم توسعهای انجام دهیم، باید در میان حجم انبوهی از کدها به دنبال قسمت مورد نظر بگردیم. - -روش دوم بهتر است اما مشکلی که وجود دارد این است که -همیشه باید به ترتیبِ کدها توجه کنیم. -بهعنوان مثال اگر بخواهیم از کد `Square` داخل `main` استفاده کنیم، -باید حتماً تگ مربوط به `Square`، قبل از تگ مربوط به `main` باشد. - -اما روش سوم هیچکدام از معایب دو روش دیگر را ندارد. -به راحتی میتوان هر زمان که به یک کد احتیاج داشتیم، آن را `import` کنیم -و فقط یک تگ `script` در HTML قرار میدهیم. - -برای روشنتر شدن موضوع، در ادامه کد روش سوم را میبینیم: - -```html title="index.html" - -``` - -```javascript title="main.js" -import {Circle} from './circle.js'; -import {Square} from './square.js'; - -const main = () => { - const circle = new Circle(10); - const square = new Square(10); - - console.log(circle.toString()); - console.log(square.toString()); -}; - -main(); -``` - -```javascript title="circle.js" -class Circle { - #radius; - - constructor(radius) { - this.#radius = Number.parseInt(radius) || 0; - } - - calculatePerimeter() { - return 2 * Math.PI * this.#radius; - } - - calculateArea() { - return Math.PI * this.#radius * this.#radius; - } - - toString() { - return `(Circle) perimeter: ${this.calculatePerimeter()}; area: ${this.calculateArea()}`; - } -} - -export {Circle}; -``` - -```javascript title="square.js" -class Square { - #side; - - constructor(side) { - this.#side = Number.parseInt(side) || 0; - } - - calculatePerimeter() { - return 4 * this.#side; - } - - calculateArea() { - return this.#side * this.#side; - } - - toString() { - return `(Square) perimeter: ${this.calculatePerimeter()}; area: ${this.calculateArea()}`; - } -} - -export {Square}; -``` - -#### import & export - -همانطور که در کد قسمت قبل مشاهده کردید، -برای آنکه بتوانیم به یک موجودیت (متغیر، تابع، کلاس و ...) در قسمتهای دیگر پروژه دسترسی داشته باشیم، -باید از کلیدواژههای `import` و `export` استفاده کنیم. - -در قسمت قبل، یک Object را `export` کردیم که تنها شامل یک عنصر با کلید `Circle` یا `Square` بود؛ -بنابراین زمانی که بخواهیم فایل را `import` کنیم، دقیقاً همان Object را به همان شکل در دسترس خواهیم داشت. -همچنین این امکان را داریم که یک موجودیت را بهعنوان شیء پیشفرض `export` کنیم -یا اسامی اشیاء را هنگام `import` عوض کنیم. - -برای آشنایی بیشتر با این مفاهیم میتوانید از لینکهای زیر استفاده کنید: - -- [MDN - export](https://developer.mozilla.org/en-US/docs/web/javascript/reference/statements/export/) -- [MDN - import](https://developer.mozilla.org/en-US/docs/web/javascript/reference/statements/import/) - ---- - -### Node.js & npm - -با استفاده از `import` میتوانید کتابخانههایی را که دیگران توسعه دادهاند، به کد خود اضافه کنید. -برای این کار مرسومترین روش استفاده از یک Package Manager است که معروفترینِ آنها npm میباشد. - -#### Setup - -برای استفاده از npm باید ابتدا با مراجعه به -[این لینک](https://nodejs.org/)، -Node.js را نصب کنید. - -Node.js -یک Runtime Environment است که به ما این امکان را میدهد که بتوانیم کد JavaScript را بدونِ نیاز به مرورگر اجرا کنیم. -از Node.js معمولاً برای برنامهنویسی سمت سرور استفاده میشود که ما در این دوره به آن نمیپردازیم -و صرفاً از npm استفاده خواهیم کرد. - -#### Package Installation - -برای پیداکردن پکیجهای مختلف میتوانید به -[سایت npm](https://www.npmjs.com/) -مراجعه کنید. - -برای نصب پکیجها، کافی است دستوری مشابه دستور زیر را در ترمینال بنویسید: - -```shell -npm i package-name -``` - -همچنین در صورتی که پکیج مورد نظر صرفاً توسط توسعهدهندگان مورد استفاده قرار میگیرد -و برای خروجی گرفتن از پروژه احتیاجی به آن نیست، -میتوانید از پارامتر `D` هنگام نصب استفاده کنید: - -```shell -npm i -D package-name -``` - -با این کار، زمانی که بخواهید پروژه را بر روی Production ببرید، -پکیجهای غیرضروری نصب نخواهند شد و فرآیند Deploy سریعتر انجام میشود. - -#### Prettier - -یکی از پکیجهای بسیار محبوب Prettier است. -Prettier -به شما کمک میکند تا قواعدی را برای فرمتکردن کد تعریف کنید. -باید دقت داشته باشید که Prettier یک فرمترِ Opinionated است؛ -به این معنا که توسعهدهندگان آن، با توجه به Conventionهای موجود و سلیقۀ خود، قواعد را تنظیم کردهاند؛ -با این حال میتوانید برخی از این قواعد را تغییر دهید. - -برای تغییر قواعد کافی است یک فایل با نام `prettierrc.` را به پروژه اضافه کنید. -ما پیشنهاد میکنیم از تنظیمات زیر برای پروژههای خود استفاده کنید: - -```json -{ - "printWidth": 120, - "tabWidth": 4, - "semi": true, - "singleQuote": true, - "trailingComma": "es5", - "bracketSpacing": false, - "arrowParens": "always", - "endOfLine": "auto", - "overrides": [ - { - "files": ["*.css", "*.scss"], - "options": { - "singleQuote": false - } - } - ] -} -``` - -همچنین اگر نمیخواهید Prettier در برخی از فایلها تغییر ایجاد کند، -میتوانید یک فایل با نام `prettierignore.` به پروژه اضافه کنید. -این فایل دقیقاً مشابه با `gitignore.` است و ما پیشنهاد میکنیم محتوای `gitignore.` را داخل این فایل نیز اضافه کنید. - -برای آشنایی بیشتر با Prettier میتوانید از لینک زیر استفاده کنید: - -- [Prettier Docs](https://prettier.io/docs/en/index.html) - -#### ESLint - -Prettier -تنها ظاهر کدهای شما را زیبا میکند؛ -اما اکثر اوقات، مخصوصاً زمانی که به صورت تیمی بر روی یک پروژه کار میکنید، -احتیاج دارید قواعدی برای تمیزی کد وضع کنید؛ -ESLint -یک پکیج استاندارد است که به شما این امکان را میدهد. - -برای وضع قوانین کافی است یک فایل با نام `eslintrc.` را به پروژه اضافه کنید. -ما پیشنهاد میکنیم از قواعد پیشفرض ESLint استفاده کنید: - -```json -{ - "extends": "eslint:recommended" -} -``` - -برای آشنایی بیشتر با این قواعد میتوانید از لینک زیر استفاده کنید: - -- [ESLint Rules](https://eslint.org/docs/latest/rules/) diff --git a/docs/frontend/phase02-dom.md b/docs/frontend/phase02-dom.md new file mode 100644 index 00000000..6f2767e2 --- /dev/null +++ b/docs/frontend/phase02-dom.md @@ -0,0 +1,371 @@ +--- +title: DOM +description: DOM گشتی در پشت پرده وب با ️ +--- + +![DOM Structure](./images/DOM.png) + +### مقدمه + +سندهای +HTML +به صورت سلسله مراتبی سازماندهی شدهاند. این ساختار به برنامهنویسان و مرورگرها اجازه میدهد تا به راحتی عناصر مختلف سند را پیدا و دستکاری کنند. در این ساختار، هر عنصر +HTML +یک گره +(Node) +است و گرهها میتوانند شامل گرههای فرزند +(Child Nodes) +باشند. این روابط سلسله مراتبی به صورت یک درخت +(Tree) +نمایش داده میشود. + +**انواع گرهها:** + +- **Root Node**: + گره ریشه در سند HTML معمولاً تگ + `` + است که تمام عناصر دیگر سند به عنوان فرزندان آن قرار میگیرند. +- **Parent Nodes**: + گرههایی که گرههای فرزند دیگری را شامل میشوند. برای مثال، تگ + `
` + یک گره والد است که ممکن است شامل گرههای فرزندی مانند تگهای + `