تیم Vue یک ابزار را جهت scaffold سریع یک پروژه Vue، به صورت رسمی ارائه کردهاست. توسط این ابزار به صورت سریع میتوانیم ساختار یک پروژه استاندارد Vue را ایجاد کنیم.
چرا نیاز به Vue CLI داریم؟
- زیرا نیاز به build processهایی داریم که به ما امکان استفاده از ES6, SCSS و دیگر ویژگیهای عالی را خواهند داد.
- جهت ساخت و یکیسازی فایلهای تمپلیت
- بارگذاری نکردن تمامی فایلها به صورت یکجا در زمان Startup
- میتوانیم تسکهایی از قبیل Server-side rendering, code-splitting را انجام دهیم.
نصب Vue CLI
ابتدا مطمئن شوید که آخرین نگارش Node.js را نصب کردهاید. سپس جهت نصب Vue CLI، خط فرمان را گشوده و دستور زیر ذیل را صادر کنید:
با اجرای فرمان فوق، ابزار CLI به صورت global و عمومی نصب خواهد شد. در ادامه میتوانیم با دستور vue list، لیستی از قالبهای رسمی را که توسط CLI قابل ایجاد هستند، مشاهده نمائید:
در اینجا ما از قالب webpack-simple استفاده خواهیم کرد. برای اینکار دستور زیر را جهت ایجاد یک پروژه بر اساس این قالب صادر کنید:
vue init webpack-simple dntVue
به این ترتیب در سریعترین زمان ممکن توانستیم یک برنامهی Vue را ایجاد کنیم:
در اینجا ساختار یک پروژه جدید Vue را مشاهده میکنید:
index.html: کار شروع و ارائه برنامه را انجام میدهد.
package.json: وابستگیهای npm برنامه را به همراه دارد.
src/App.vue: کامپوننت اصلی برنامه است.
پوشه src/assets: حاوی فایلهای استاتیک پروژه است.
src/main.js: نقطهی آغاز برنامه است.
webpack.config.json: تنظیمات وبپک جهت اجرای پروژه و بارگذاری ماژولهای موردنیاز.
اجرای برنامه
ابتدا نیاز است وابستگیهای برنامه دریافت شوند. اینکار را توسط دستور npm install و یا دستور yarn (در صورتیکه yarn را از قبل بر روی سیستم خود نصب کردهاید) انجام خواهیم داد:
به این ترتیب تمامی وابستگیهای پروژه درون پوشهی node_module تشکیل خواهند شد. اکنون میتوانیم با صدور دستور npm run dev پروژه را اجرا کنیم:
بررسی فایلهای Vue
درون یک برنامهی Vue واقعی، فایلهایی با پسوند vue. وجود دارند. این فایل شامل تمپلیت، کدها و همچنین استایلهای یک کامپوننت میباشند.
<template>
<div>
<!-- Write your HTML with Vue in here -->
</div>
</template>
<script>
export default {
// Write your Vue component logic here
}
</script>
<style scoped>
/* Write your styles for the component in here */
</style>
بنابراین درون فایلی با ساختار فوق، تمامی موارد مورد نیاز برای یک کامپوننت ویو را خواهیم داشت و به اصطلاح نیازی به context switching نخواهیم داشت؛ زیرا تمامی قسمتها را به صورت یکجا در یک محل در اختیار داریم و به راحتی میتوانیم تمرکز خود را بر روی کدها قرار دهیم. درون کامپوننت نیز میتوانیم کامپوننتهای موردنیاز را ایمپورت و از آن استفاده کنیم:
import { New } from "./components/New.vue";
export default {
components: {
New
}
}
Vue CLI 3
تا اینجا از نسخهی پایدار Vue CLI استفاده کردیم. نسخهی 3 آن هنوز در مرحلهی beta قرار دارد. در این نسخه امکانات و دستورات بیشتری اضافه شدهاست؛ از ایجاد یک پروژه ساده تا ایجاد یک پروژه مبتنی بر TypeScript. برای نصب و یا آپگرید میتوانید از دستور زیر استفاده کنید:
اکنون میتوانید با صادر کردن دستور vue --version، شماره نسخهی آن را مشاهده نمائید:
ایجاد یک پروژه جدید
برای ایجاد یک پروژه جدید میتوانید دستور زیر را صادر کنید:
همانطور که مشاهده میکنید در این نسخه بجای استفاده از دستور vue init، از vue create استفاده شده است. در اینحالت میتوانید نوع ایجاد پروژه را تعیین کنید:
Vue CLI v3.0.0-beta.11
? Please pick a preset: (Use arrow keys)
❯ default (babel, eslint)
Manually select features
حالت پیشفرض، چنین ساختاری را برایتان ایجاد خواهد کرد:
بعد از طی کردن مراحل، میتوانید قالب پروژهی ایجاد شده را به صورت یک preset داشته باشید تا در پروژههای آینده مجبور نباشید مراحل قبل را طی کنید. این preset درون یک فایل JSON به صورت زیر ذخیره خواهد شد و حاوی اطلاعات زیر است:
{
"useConfigFiles": true,
"router": true,
"vuex": true,
"cssPreprocessor": "sass",
"plugins": {
"@vue/cli-plugin-babel": {},
"@vue/cli-plugin-eslint": {
"config": "airbnb",
"lintOn": ["save", "commit"]
}
}
}
در حالت manually نیز میتوانید گزینههای بیشتری را برای تعیین نوع قالب پروژه، انتخاب نمائید. به عنوان مثال میتوان از TypeScript یا اینکه از lintter یا formatter خاصی برای کدها استفاده کرد:
در ادامه دیگر آپشنها را نیز میتوانید تعیین کرده و در نهایت به صورت یک قالب از پیش تعریف شده نیز پروژه را داشته باشید:
Zero-config Prototyping
یکی از قابلیتهای جالب Vue، امکان تهیه سریع prototype یا طرح اولیه میباشد. شاید اکثر اوقات نیاز داشته باشید یک ویژگی یا قابلیت خاص را با Vue تست کنید. در این موارد ممکن است از سایتی مانند CodePen استفاده کنید. اما توسط افزونهی cli-service-global میتوانید به صورت لوکال و بدون نیاز به راهاندازی یک پروژهی جدید، کدهای موردنیاز را آزمایش کنید. فرض کنید میخواهیم تمپلیت زیر را قبل از افزودن آن به پروژه، مورد تست قرار دهیم:
<!-- MyCard.vue -->
<template>
<div class="card">
<h1>Card Title</h1>
<p>Card content goes here. Make sure it's not Lorem.</p>
</div>
</template>
در اینحالت میتوانیم با نصب افزونه موردنظر، فایل فوق را به راحتی و بدون نیاز به راهاندازی یک پروژه جدید، تست کنیم:
npm install -g @vue/cli-service-global
اکنون میتوانیم خروجی را با صدور فرمان زیر درون مرورگر مشاهده کنیم:
با صدرو فرمان فوق، فایل توسط افزونهی عنوان شده، از طریق مرورگر قابل دسترسی میباشد:
خروجی: