Skip to content

الاختصارات

تسمح لك الاختصارات بدمج قواعد متعددة في اختصار واحد، مستوحاة من Windi CSS.

الاستخدام

ts
shortcuts: {
  // اختصارات لأدوات متعددة
  'btn': 'py-2 px-4 font-semibold rounded-lg shadow-md',
  'btn-green': 'text-white bg-green-500 hover:bg-green-700',
  // اسم مستعار لأداة واحدة
  'red': 'text-red-100',
}

بالإضافة إلى التعيين العادي، يسمح UnoCSS أيضاً بتعريف اختصارات ديناميكية.

مشابه لـ القواعد، الاختصار الديناميكي هو مزيج من matcher RegExp ودالة المعالج.

ts
shortcuts: [
  // يمكنك لا تزال الحصول على نمط الكائن
  {
    btn: 'py-2 px-4 font-semibold rounded-lg shadow-md',
  },
  // اختصارات ديناميكية
  [/^btn-(.*)$/, ([, c]) => `bg-${c}-400 text-${c}-100 py-2 px-4 rounded-lg`],
]

مع هذا، يمكننا استخدام btn-green و btn-red لتوليد CSS التالي:

css
.btn-green {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  padding-right: 1rem;
  --un-bg-opacity: 1;
  background-color: rgb(74 222 128 / var(--un-bg-opacity));
  border-radius: 0.5rem;
  --un-text-opacity: 1;
  color: rgb(220 252 231 / var(--un-text-opacity));
}
.btn-red {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  padding-right: 1rem;
  --un-bg-opacity: 1;
  background-color: rgb(248 113 113 / var(--un-bg-opacity));
  border-radius: 0.5rem;
  --un-text-opacity: 1;
  color: rgb(254 226 226 / var(--un-text-opacity));
}

Released under the MIT License.