ربط التنسيقات و الأصناف
احتياج شائع لربط البيانات هو التحكم في قائمة الأصناف وتنسيقات العنصر. بما أن class
و style
عبارة عن سمتين، يمكننا استخدام v-bind
لاعطائهما سلسلة نصية كقيمة بشكل ديناميكي، على غرار السمات الأخرى. ومع ذلك، يمكن أن يكون توليد هذه القيم عن طريق ربط سلاسل مزعجًا ومُحتملًا للأخطاء. لهذا السبب، توفر Vue تحسينات خاصة عند استخدام v-bind
مع class
و style
. بالإضافة إلى السلاسل النصية، يمكن أن تُقيّم العبارات أيضًا إلى كائنات أو مصفوفات.
ربط أصناف الـHTML
الربط بالكائنات
يمكننا تمرير كائن إلى :class
(الإختصار لـ v-bind:class
) لتبديل الأصناف بشكل ديناميكي:
template
<div :class="{ active: isActive }"></div>
الصيغة أعلاه تعني أن وجود الصنف active
سيتم تحديده بواسطة صحة الخاصية isActive
من البيانات.
يمكن أن يكون لديك عدة أصناف تتبدل بواسطة وجود العديد من الخاصيات في الكائن. بالإضافة إلى ذلك، يمكن للسمة المربوطة :class
أيضًا أن تكون موجودة بجانب السمة class
العادية. لذا، بالنظر إلى الحالة التالية:
js
const isActive = ref(true)
const hasError = ref(false)
و القالب الموالي:
template
<div
class="static"
:class="{ active: isActive, 'text-danger': hasError }"
></div>
سيتم تصيير العنصر التالي:
template
<div class="static active"></div>
عند تغيير isActive
أو hasError
، سيتم تحديث قائمة الصنف بناءً على ذلك. على سبيل المثال، إذا أصبح hasError
true
، فسيصبح قائمة الصنف "static active text-danger"
.
الكائن المربوط لا يحتاج أن يكون مُضمَّنا:
js
const classObject = reactive({
active: true,
'text-danger': false
})
template
<div :class="classObject"></div>
سيقوم هذا الربط بتصيير نفس النتيجة. يمكننا أيضًا الربط بخاصية محسوبة تعيد كائنًا. و هو نمط شائع وقوي:
js
const isActive = ref(true)
const error = ref(null)
const classObject = computed(() => ({
active: isActive.value && !error.value,
'text-danger': error.value && error.value.type === 'fatal'
}))
template
<div :class="classObject"></div>
الربط بالمصفوفات
يمكننا ربط :class
بمصفوفة لتطبيق قائمة من الأصناف:
js
const activeClass = ref('active')
const errorClass = ref('text-danger')
template
<div :class="[activeClass, errorClass]"></div>
نتيجة التصيير :
template
<div class="active text-danger"></div>
إذا كنت ترغب أيضًا في تبديل صنف في القائمة بشكل شرطي، يمكنك القيام بذلك باستخدام تعبير ثلاثي:
template
<div :class="[isActive ? activeClass : '', errorClass]"></div>
هذا الربط سيطبق دائمًا errorClass
، ولكن activeClass
سيتم تطبيقه فقط عندما يكون isActive
صحيحًا.
لكن قد يكون هذا طويلا نوعا ما إذا كان لديك أصناف شرطية متعددة. لهذا السبب، يمكنك أيضًا استخدام صيغة الكائن داخل صيغة المصفوفة :
template
<div :class="[{ active: isActive }, errorClass]"></div>
مع المكونات
هذا القسم يفترض أن لديك معرفة بالمكونات. لا تتردد في تخطيه والعودة إليه لاحقًا.
لما تستخدم السمة class
على مكون يحتوي على عنصر جذري واحد فقط، سيضاف هذا الصنف إلى العنصر الجذري للمكون، وسيدمج مع أي صنف موجود عليه من قبل.
على سبيل المثال، إذا كان لدينا مكون يسمى MyComponent
مع القالب التالي:
template
<!-- قالب المكون الابن -->
<p class="foo bar">مرحبا!</p>
ثم اضف بعض الأصناف عند استخدامه:
template
<!-- عند استخدام المكون -->
<MyComponent class="baz boo" />
الـHTML المصيّر سيكون بالشكل الموالي :
template
<p class="foo bar baz boo">مرحبا!</p>
نفس الشيء ينطبق على ربط الصنف:
template
<MyComponent :class="{ active: isActive }" />
لما يكون isActive
صحيحًا، سيكون الـHTML المصيّر بالشكل الموالي :
template
<p class="foo bar active">مرحبا!</p>
إذا كان لديك مكون يحتوي على عناصر جذرية متعددة، ستحتاج إلى تحديد أي عنصر سيتلقى هذا الصنف. يمكنك القيام بذلك باستخدام خاصية المكون attrs$
:
template
<!-- قالب MyComponent باستخدام $attrs -->
<p :class="$attrs.class">مرحبا!</p>
<span>هذا هو المكون الابن</span>
template
<MyComponent class="baz" />
النتيجة المصيرة ستكون:
html
<p class="baz">مرحبا!</p>
<span>هذا هو المكون الابن</span>
يمكنك معرفة المزيد عن توريث سمات المكون في قسم السمات المستترة.
ربط التنسيقات السطرية
الربط بالكائنات
:style
يدعم ربط قيم كائنات JavaScript - يُوافق مع خاصية style
لعنصر HTML:
js
const activeColor = ref('red')
const fontSize = ref(30)
template
<div :style="{ color: activeColor, fontSize: fontSize + 'px' }"></div>
رغم أن الأسماء المكتوبة باستخدام نمط سنام الجمل camelCase موصى بها، إلا أن style:
يدعم أيضًا أسماء الخاصيات CSS مكتوبة باستخدام نمط أسياخ الشواء kebab-case (وهي ما يستخدم في CSS الفعلي) - على سبيل المثال:
template
<div :style="{ 'font-size': fontSize + 'px' }"></div>
غالبا ما يكون من الأفضل ربط كائن التنسيقات مباشرة حتى يكون محتوى القالب أنقى:
js
const styleObject = reactive({
color: 'red',
fontSize: '13px'
})
template
<div :style="styleObject"></div>
مرة أخرى، يتم استخدام ربط كائن التنسيقات عادةً مع خاصيات محسوبة تُعيد كائنات.
الربط بالمصفوفات
يمكننا ربط :style
بمصفوفة من كائنات متعددة من التنسيقات . سيتم دمج هذه الكائنات وتطبيقها على نفس العنصر:
template
<div :style="[baseStyles, overridingStyles]"></div>
البادئة التلقائية
لما تستخدم خاصية CSS والتي تتطلب بادئة في :style
، ستُضِيف Vue البادئة المناسبة تلقائيًا. تقوم Vue بذلك من خلال التحقق في وقت التشغيل لمعرفة أي خاصيات النمط المدعومة في المتصفح الحالي. إذا لم يدعم المتصفح خاصية معينة سيختبر بعدها مختلف أنواع البادئات للحصول على أحد البادئات المدعومة.
قيم متعددة
يمكنك امداد مصفوفة من القيم المتعددة (ذات بادئة) إلى خاصية التنسيق، على سبيل المثال:
template
<div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>
هذه الشيفرة ستصير القيمة الأخيرة فقط في المصفوفة التي يدعمها المتصفح. في هذا المثال، ستقوم بتصيير display: flex
للمتصفحات التي تدعم نسخة بدون بادئة من flexbox.