سناریویی را در نظر بگیرید که برای هر کدام از مدلهای Article, Video, Event میخواهیم قابلیت کامنتگذاری جداگانهای را داشته باشیم. چندین روش برای پیادهسازی این سناریو وجود دارد که در ادامه به آنها خواهیم پرداخت. Polymorphic association در این روش بجای تعریف چند کلید خارجی، تنها یک فیلد جنریک را تعریف خواهیم کرد که میتواند همزمان یک ارجاع را به مدلهای مطرح شده داشته باشد. برای تعیین نوع کلید هم نیاز به یک فیلد دیگر جهت ...
Feather HTTP یک فریمورک HTTP سبک، برای ایجاد APIهای NET Core. است، در واقع یک wrapper بر روی APIهای موجود ASP.NET Core میباشد که به ما امکان ایجاد HTTP API را در کمترین زمان میدهد. در این مطلب نحوه ایجاد یک API را توسط این فریمورک بررسی خواهیم کرد. معرفی قالب FeatherHttp.Templates به سیستم dotnet برای شروع میتوانیم قالب پروژه Feather HTTP را به لیست قالبهای از پیش نصب شدهی dotnet اضافه کنیم. برای اینکار کافی است در خط ...
استفاده از Redux درون پروژههای React، به روشهای مختلفی قابل انجام است؛ یعنی محدودیتی از لحاظ نحوه چیدمان فایلها، تغییر state و نحوهی dispatch کردن action وجود ندارد. به عبارتی این آزادی عمل را خواهیم داشت تا خودمان سیمکشی پروژه را انجام دهیم؛ ولی مشکل اصلی اینجاست که نمیتوانیم مطمئن شویم روشی که پروژه را با آن ستاپ کردهایم آیا به عنوان یک best-practice محسوب میشود یا خیر. در نهایت خروجی را که خواهیم داشت، حجم انبوهی از کدهای boiler ...
فرض کنید میخواهیم دادههایی را از دیتابیس بخوانیم و در نهایت درون UI نمایش دهیم. شاید فکر کنید که متد render مکان مناسبی برای اینکار باشد: render() {
fetch('https://jsonplaceholder.typicode.com/users')
.then(response => response.json())
.then(data => this.setState({ users: data }))
return (
<ul>
{this.state.users.map(user => <li key={user.id}>{u ...
در پروژههای React، نقطهی آغازین فرآیند rendering، قطعه کد زیر میباشد که درون فایل index.js قرار دارد: ReactDOM.render(<App />, document.getElementById('root'));
توسط متد ReactDOM.render یک وهله از کامپوننت App ایجاد شده و منجر به فراخوانی متد render کامپوننت مربوطه خواهد شد. درون متد ذکر شده ممکن است چندین کامپوننت تعریف شده باشند. در نتیجه به ازای هر کامپوننت، متد render متناظر با آن فراخوانی خواهد شد. در نهایت یک س ...
در ASP.NET Core یک View Component ، در نهایت خلاصهایی از قابلیتهایی را ارائه میدهد که قرار است توسط یک کنترلر مدیریت شوند؛ زیرا پارامترهای یک View Component از طریق یک HTTP Request تامین نمیشوند. یعنی به صورت مستقیم از طریق درخواستهای HTTP قابل دسترسی نیستند. فرض کنید در یک برنامه میخواهیم لیست کاربران سایت را نمایش دهیم تا با کلیک بر روی نام کاربر، امکان ویرایش کاربر انتخاب شده را داشته باشیم. با کلیک بر روی لینک مورد نظر، اطلاعات ...
مدیریت پکیجهای سمت کلاینت پروژههای جدیدی که با استفاده از قالب پیشفرض ایجاد میشوند، شامل یک پوشه با نام lib، در شاخهی wwwroot هستند که حاوی این فایلها میباشند: اینها به عنوان حداقلهای ایجاد یک وب اپلیکیشن، برای قالب انتخاب شده در نظر گرفته شدهاند. اما فرض کنید بعد از مدتی میخواهیم ورژن bootstrap استفاده شده در پروژه را ارتقاء دهیم؛ در این حالت چندین انتخاب داریم: دانلود مستقیم فایل مور ...
هر وهله از Vue از یکسری مراحل یا (initialization steps) عبور خواهد کرد به عنوان مثال مراحلی از قبیل کامپایل شدن تمپلیت، mount شدن وهله به DOM و یا بروزرسانی DOM زمانیکه دادهها تغییر پیدا میکنند و ... در حین طی کردن این مسیر یکسری توابع ویژه با نام lifecycle hooks فراخوانی خواهند شد. بنابراین درون این توابع میتوانیم در هر مرحله کدهای موردنیازمان را قرار دهیم: همانطور که مشاهده میکنید این چرخه حیات با وهلهسازی شیء Vue شروع می ...
تیم Vue یک ابزار را جهت scaffold سریع یک پروژه Vue، به صورت رسمی ارائه کردهاست. توسط این ابزار به صورت سریع میتوانیم ساختار یک پروژه استاندارد Vue را ایجاد کنیم. چرا نیاز به Vue CLI داریم؟ زیرا نیاز به build processهایی داریم که به ما امکان استفاده از ES6, SCSS و دیگر ویژگیهای عالی را خواهند داد. جهت ساخت و یکیسازی فایلهای تمپلیت بارگذاری نکردن تمامی فایلها به صورت یکجا در زمان Startup میتوانیم ...
پیشتر در سایت مطالبی در رابطه با فریمورک Vue.js منتشر شدهاست. در این مطلب میخواهیم نگاهی بر مفهوم کامپوننتها در Vue بیندازیم و نحوهی استفاده از آنها را بررسی کنیم. قبل از معرفی کامپوننتها اجازه دهید سیستم template در ویو را بررسی کنیم. سیستم template ویو براساس سینتکس HTML است: new Vue({
el: '#app',
template: '<div>Hello DNT</div>'
});
البته استفاده از template کاملاً اختیاری است. بجای آن میتو ...