Skip to content

پلاگین‌ها - Plugins

مقدمه

پلاگین‌ها کدهای مستقلی هستند که معمولاً عملکردهایی را در سطح برنامه به Vue اضافه می کنند. وقتی از یک پلاگین در برنامه Vue.js استفاده می‌کنید، کدهایی را اضافه می‌کنید که عملکرد برنامه شما را با ارائه ویژگی‌ها یا ابزارهای اضافی که می‌توان به آنها دسترسی پیدا کرد و در سراسر برنامه استفاده کرد، گسترش می‌دهد. به روش زیر پلاگین را نصب می‌کنیم:

js
import { createApp } from 'vue'

const app = createApp({})

app.use(myPlugin, {
  /* آپشن‌های اختیاری */
})

یک پلاگین یا به عنوان یک آبجکت تعریف می‌شود که یک متد install()‎ دارد، یا به سادگی یک تابع است که خودش به عنوان تابع نصب عمل می‌کند. این تابع می‌تواند دسترسی به نمونه برنامه اصلی شما داشته باشد و همچنین اگر شما در زمان استفاده از پلاگین (استفاده از app.use()‎) آپشن‌های اضافی ارائه کرده باشید، این آپشن‌ها را نیز دریافت کند.

js
const myPlugin = {
  install(app, options) {
    // برنامه را کانفیگ کنید
  }
}

مواقع رایجی که استفاده از پلاگین‌ها مفید است عبارتند از:

  1. ثبت یک یا چند کامپوننت سراسری یا دستورات سفارشی با استفاده از app.component()‎ و app.directive()‎.

  2. ایجاد یک منبع قابل تزریق (injectable) در سراسر برنامه با فراخوانی app.provide()‎.

  3. اضافه کردن ویژگی‌ها یا متدهای سراسری با اتصال آنها به app.config.globalProperties.

  4. کتابخانه‌ای که باید ترکیبی از موارد فوق را انجام دهد (مثلاً vue-router).

نوشتن یک پلاگین‌

به منظور درک بهتر نحوه ایجاد پلاگین‌ها در Vue.js، ما یک نسخه ساده شده از یک پلاگین‌ را ایجاد خواهیم کرد که رشته‌های i18n (کوتاه شده ی Internationalization یا همان بین‌المللی‌سازی) را نمایش می‌دهد.

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

js
// plugins/i18n.js
export default {
  install: (app, options) => {
    // کد پلاگین اینجا نوشته می شود.
  }
}

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

template
<h1>{{ $translate('greetings.hello') }}</h1>

از آنجایی که این تابع باید به صورت گلوبال در تمام تمپلیت‌ها در دسترس باشد، آن را به app.config.globalProperties متصل می‌کنیم:

js
// plugins/i18n.js
export default {
  install: (app, options) => {
    // به شکل سراسری $translate() تزریق متد
    app.config.globalProperties.$translate = (key) => {
      // `options` یافتن یک ویژگی تو در تو در 
      // به عنوان مسیر `key` با استفاده از
      return key.split('.').reduce((o, i) => {
        if (o) return o[i]
      }, options)
    }
  }
}

تابع ‎$translate ما یک رشته مانند greetings.hello را دریافت می‌کند، در تنظیماتی که توسط کاربر ارائه شده است جستجو می‌کند و مقدار ترجمه‌شده را باز می‌گرداند.

در هنگام نصب پلاگین، باید آبجکت حاوی مقادیر ترجمه شده را به app.use()‎ منتقل کنیم:

js
import i18nPlugin from './plugins/i18n'

app.use(i18nPlugin, {
  greetings: {
    hello: 'Bonjour!'
  }
})

حالا، عبارت اولیه ما ‎$translate('greetings.hello') در زمان اجرا با Bonjour!‎ جایگزین می‌شود.

مشاهده کنید: افزودن ویژگی‌های جهانی

نکته

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

ارائه / تزریق پلاگین

پلاگین‌ها در Vue.js انعطاف‌پذیری را برای استفاده از ویژگی inject ارائه می‌دهند که به ما امکان می‌دهد یک عملکرد یا پراپرتی را به کاربران پلاگین‌ ارائه دهیم. به عنوان مثال، ما می‌توانیم امکان دسترسی به پارامتر options را به برنامه بدهیم تا بتواند از آبجکت حاوی مقادیر ترجمه شده استفاده کند.

js
// plugins/i18n.js
export default {
  install: (app, options) => {
    app.provide('i18n', options)
  }
}

کاربران پلاگین‌ اکنون می توانند با استفاده از کلید i18n پراپرتی‌های پلاگین‌ را به کامپوننت خود تزریق کنند:

vue
<script setup>
import { inject } from 'vue'

const i18n = inject('i18n')

console.log(i18n.greetings.hello)
</script>
js
export default {
  inject: ['i18n'],
  created() {
    console.log(this.i18n.greetings.hello)
  }
}
پلاگین‌ها - Plugins has loaded