الخاصية background-position

من موسوعة حسوب
< CSS
مراجعة 13:45، 28 أكتوبر 2017 بواسطة عبد اللطيف ايمش (نقاش | مساهمات)
(فرق) → مراجعة أقدم | المراجعة الحالية (فرق) | مراجعة أحدث ← (فرق)

الخاصية background-position في CSS تضبط الموضع المبدئي لكل صورة خلفية، وذلك نسبةً إلى المبدأ المُعرَّف في الخاصية background-origin.

/* كلمات محجوزة */
background-position: top;
background-position: bottom;
background-position: left;
background-position: right;
background-position: center;

/* نسب مئوية */
background-position: 25% 75%;

/* أطوال مطلقة */
background-position: 0 0;
background-position: 1cm 2cm;
background-position: 10ch 8em;

/* عدِّة صور */
background-position: 0 0, center;

/* مسافات فاصلة عن الحواف */
background-position: bottom 10px right 20px;
background-position: right 3em bottom 10px;
background-position: bottom 10px right;
background-position: top right 10px;

/* القيم العامة */
background-position: inherit;
background-position: initial;
background-position: unset;
صورة تبيّن قيمًا مختلفة مسندة إلى الخاصية background-position.
صورة تبيّن قيمًا مختلفة مسندة إلى الخاصية background-position.
القيمة الابتدائية 0% 0%
تُطبَّق على جميع العناصر.
قابلة للوراثة لا
قابلة للتحريك نعم
القيمة المحسوبة قائمة فيها أكثر من عنصر، وكل عنصر يتألف من كلمتين محجوزتين تمثلان المبدأ ومسافات فاصلة عن الحواف، والتي تعطى بأطوال مطلقة (<length>)، أو ستعتبر على أنها نسب مئوية.

أمثلة

القاعدتان الآتيتان ستؤديا إلى توسيط صورة الخلفية في العنصر، لاحظ أنَّنا استخدامنا الكلمة المحجوزة center في أوّل قاعدة، والنسبة المئوية 50% في القاعدة الثانية:

background-position: center;
background-position: 50% 50%;

أما لضبط موضع صورة الخلفية إلى الركن السفلي الأيمن للعنصر، فيمكن أن نستعمل الكلمتين المحجوزتين bottom و right، لاحظ أنَّ ترتيب الكلمتين المحجوزتين غير مهم لأننا لم نستخدم قيمةً طوليةً <length> أو نسبةً مئويةً <percentage> في القاعدة:

background-position: bottom right;
background-position: right bottom;

تحديد أنَّ صورة الخلفية ستكون على مسافة 10px من الحافة اليسرى وتكون مجاورة للحافة السفلية:

background-position: left 10px bottom;

تحديد أنَّ صورة الخلفية ستكون على مسافة 10px من الحافة اليسرى وتكون على مسافة 1em من الحافة السفلية:

background-position: left 10px bottom 1em;

دعم المتصفحات

الميزة Chrome Firefox Internet Explorer Opera Safari
الدعم الأساسي 1.0 1.0 4.0 3.5 1.0
تعدد الخلفيات 1.0 3.6 9.0 10.5 1.3

البنية العامة

تقبل الخاصية background-position أكثر من قيمة <position> مفصولٌ بينها بفاصلة.

القيمة <position>

تُعرِّف القيمة <position> إحداثيات XY لموضع الصورة نسبةً إلى حواف صندوق العنصر، ويمكن أن تُحدَّد هذه القيمة بأحد الشكلين الآتيين:

تحديد قيمة واحدة

يمكن أن تكون هذه القيمة:

  • الكلمة المحجوزة center، التي توسِّط الصورة.
  • إحدى الكلمات المحجوزة top أو left أو bottom أو right، والتي تُحدِّد ما هي الحافة التي ستوضع الصورة بجوارها، وسيُضبَط البعد الآخر إلى 50%، أي أنَّ الصورة ستوضع في منتصف الحافة المُحدَّدة.
  • طول <length> أو نسبة مئوية <percentage>؛ واللذان يحددان إحداثيات X نسبةً إلى الحافة اليسرى، وستُضبَط قيمة Y تلقائيًا إلى 50%.

تحديد قيمتين اثنتين

تُعرِّف أوّل قيمة إحداثيات X (أي right أو left أو center)، والقيمة الثانية إحداثيات Y (أي top أو bottom أو center)، ويمكن أن تكون أيُّ واحدةٍ منها إحدى القيم الآتية:

  • إحدى الكلمات المحجوزة top أو left أو bottom أو right، وإذا استخدمنا left أو right فسنضبط إحداثيات X وستُحدِّد القيمة الأخرى إحداثيات Y، وإذا استخدمنا top أو bottom فسنضبط إحداثيات Y وستُحدِّد القيمة الأخرى إحداثيات X.
  • طول <length> أو نسبة مئوية <percentage>؛ وإذا كانت القيمة الأخرى left أو right فستحدِّد هذه القيمة إحداثيات Y نسبةً إلى الحافة العلوية، وإذا كانت القيمة الأخرى top أو bottom فستُحدِّد هذه القيمة إحداثيات X نسبةً إلى الحافة اليسرى؛ وإذا كانت كلا القيمتين طولًا <length> أو نسبةً مئويةً <percentage> فستعرِّف أوّل قيمة إحداثيات X والقيمة الثانية إحداثيات Y.

لاحظ أنَّه:

  • إذا كانت أوّل قيمة top أو bottom، فلا يجوز أن تكون القيمة الثانية top أو bottom.
  • وإذا كانت أوّل قيمة left أو right، فلا يجوز أن تكون القيمة الثانية left أو right، وهذا يعني أنَّ القيم top top و left right غير صالحة.
  • إذا كانت كلا القيمتين كلمتين محجوزتين، فيمكن أن تكونا بأي ترتيب تشاء (مثل top left أو left top)، لكن لا يجوز تغيير ترتيب القيم إن كان إحداهما قيمةً طوليةً أو نسبةً مئويةً (أي يجوز استخدام left 10px لكن لا يجوز استخدام 10px left).

تحديد ثلاث أو أربع قيم

أضيف حديثًا دعمٌ لتحديد ثلاث أو أربع قيم، والقيم الإضافية تُمثِّل مقدار الإزاحة عن الحافة، وتأتي الإزاحة بعد الكلمة المحجوزة. فالقيمة left 10px bottom 1em تعني أنَّ صورة الخلفية ستبعد 10px عن الحافة اليسرى للعنصر، و 1em عن الحافة السفلية له.

لاحظ أنَّ بإمكاننا ضبط الإزاحة عن الحافة اليسرى فقط بحذف قيمة الإزاحة بعد الكلمة المحجوزة الثانية، كما في left 10px bottom، أو حذف الإزاحة عن الحافة السفلية فقط بحذف قيمة الإزاحة عن الكلمة المحجوزة الأولى كما في left bottom 1em.

البنية الرسمية

background-position: <position>#;

حيث:

<position> = [[ left | center | right | top | bottom | <length-percentage> ] | [ left | center | right | <length-percentage> ] [ top | center | bottom | <length-percentage> ] | [ center | [ left | right ] <length-percentage>? ] && [ center | [ top | bottom ] <length-percentage>? ]]

حيث:

<length-percentage> = <length> | <percentage>

مصادر ومواصفات