الفرق بين المراجعتين ل"CSS/border-radius"

من موسوعة حسوب
< CSS
اذهب إلى التنقل اذهب إلى البحث
 
 
(7 مراجعات متوسطة بواسطة مستخدمين اثنين آخرين غير معروضة)
سطر 1: سطر 1:
 
<noinclude>{{DISPLAYTITLE:الخاصية <code>border-radius</code>}}</noinclude>
 
<noinclude>{{DISPLAYTITLE:الخاصية <code>border-radius</code>}}</noinclude>
الخاصية <code>border-radius</code> في CSS تسمح لمطوري الويب بتعريف طريقة تدوير أركان الإطار، ويمكن تحديد قيمة واحدة لجعل الأركان دائريةً، أو قيمتين لجعلها على شكل قطع ناقص.<syntaxhighlight lang="css">
+
الخاصية <code>border-radius</code> في CSS تسمح لمطوري الويب بتعريف طريقة تدوير أركان الإطار، ويمكن تحديد قيمة واحدة لجعل الأركان دائريةً، أو قيمتين لجعلها على شكل قطع ناقص.
 +
== بطاقة الخاصية ==
 +
{| class="wikitable" style="width: 100%;"
 +
|-
 +
! scope="row" style="width: 20%;" |[[CSS/initial value|القيمة الابتدائية]]
 +
|لكل قيمة مختصرة:
 +
*<code>[[CSS/border-top-left-radius|border-top-left-radius]]</code>: <code>0</code>
 +
*<code>[[CSS/border-top-right-radius|border-top-right-radius]]</code>: <code>0</code>
 +
*<code>[[CSS/border-bottom-left-radius|border-top-left-radius]]</code>: <code>0</code>
 +
*<code>[[CSS/border-bottom-right-radius|border-top-right-radius]]</code>: <code>0</code>
 +
|-
 +
! scope="row" |تُطبَّق على
 +
|جميع العناصر.
 +
|-
 +
! scope="row" |قابلة للوراثة
 +
|لا
 +
|-
 +
!قابلة للتحريك
 +
|نعم
 +
|-
 +
!النسب المئوية
 +
|نسبة من البُعد الموافق للقيمة من إطار العنصر.
 +
|-
 +
! scope="row" |القيمة المحسوبة
 +
|لكل قيمة مختصرة:
 +
*<code>[[CSS/border-top-left-radius|border-top-left-radius]]</code>: قيمتَي <code>[[CSS/length|<length>]]</code> أو نسبتين مئويتين <code>[[CSS/percentage|<percentage>]]</code>.
 +
*<code>[[CSS/border-top-right-radius|border-top-right-radius]]</code>: قيمتَي <code>[[CSS/length|<length>]]</code> أو نسبتين مئويتين <code>[[CSS/percentage|<percentage>]]</code>.
 +
*<code>[[CSS/border-bottom-left-radius|border-top-left-radius]]</code>: قيمتَي <code>[[CSS/length|<length>]]</code> أو نسبتين مئويتين <code>[[CSS/percentage|<percentage>]]</code>.
 +
*<code>[[CSS/border-bottom-right-radius|border-top-right-radius]]</code>: قيمتَي <code>[[CSS/length|<length>]]</code> أو نسبتين مئويتين <code>[[CSS/percentage|<percentage>]]</code>.
 +
 
 +
|}
 +
<syntaxhighlight lang="css">
 
/* ضبط التدوير لجميع الأركان معًا */
 
/* ضبط التدوير لجميع الأركان معًا */
 
border-radius: 10px;
 
border-radius: 10px;
سطر 36: سطر 67:
  
 
وكما مع جميع الخاصيات مختصرة، لا يمكن توريث القيم المفردة، كما في <code>border-radius:0 0 inherit inherit</code>، وعندئذٍ يجب استخدام الخاصيات الطويلة كلًا على حدة.
 
وكما مع جميع الخاصيات مختصرة، لا يمكن توريث القيم المفردة، كما في <code>border-radius:0 0 inherit inherit</code>، وعندئذٍ يجب استخدام الخاصيات الطويلة كلًا على حدة.
{| class="wikitable" style="width: 100%;"
 
|-
 
! scope="row" style="width: 20%;" |[[CSS/initial value|القيمة الابتدائية]]
 
|لكل قيمة مختصرة:
 
*<code>[[CSS/border-top-left-radius|border-top-left-radius]]</code>: <code>0</code>
 
*<code>[[CSS/border-top-right-radius|border-top-right-radius]]</code>: <code>0</code>
 
*<code>[[CSS/border-bottom-left-radius|border-top-left-radius]]</code>: <code>0</code>
 
*<code>[[CSS/border-bottom-right-radius|border-top-right-radius]]</code>: <code>0</code>
 
|-
 
! scope="row" |تُطبَّق على
 
|جميع العناصر.
 
|-
 
! scope="row" |قابلة للوراثة
 
|لا
 
|-
 
!قابلة للتحريك
 
|نعم
 
|-
 
!النسب المئوية
 
|نسبة من البُعد الموافق للقيمة من إطار العنصر.
 
|-
 
! scope="row" |القيمة المحسوبة
 
|لكل قيمة مختصرة:
 
*<code>[[CSS/border-top-left-radius|border-top-left-radius]]</code>: قيمتَي <code>[[CSS/length|<length>]]</code> أو نسبتين مئويتين <code>[[CSS/percentage|<percentage>]]</code>.
 
*<code>[[CSS/border-top-right-radius|border-top-right-radius]]</code>: قيمتَي <code>[[CSS/length|<length>]]</code> أو نسبتين مئويتين <code>[[CSS/percentage|<percentage>]]</code>.
 
*<code>[[CSS/border-bottom-left-radius|border-top-left-radius]]</code>: قيمتَي <code>[[CSS/length|<length>]]</code> أو نسبتين مئويتين <code>[[CSS/percentage|<percentage>]]</code>.
 
*<code>[[CSS/border-bottom-right-radius|border-top-right-radius]]</code>: قيمتَي <code>[[CSS/length|<length>]]</code> أو نسبتين مئويتين <code>[[CSS/percentage|<percentage>]]</code>.
 
 
|}
 
  
 
== أمثلة ==
 
== أمثلة ==
سطر 93: سطر 95:
 
}
 
}
 
</syntaxhighlight>مثال عن تدوير أركان أحد العناصر مع تحديد إطار <code>[[CSS/border|border]]</code> له:<syntaxhighlight lang="html">
 
</syntaxhighlight>مثال عن تدوير أركان أحد العناصر مع تحديد إطار <code>[[CSS/border|border]]</code> له:<syntaxhighlight lang="html">
<div>thick border with border-radius</div>
+
<div>إطار سميك مع خاصية تدوير الإطار</div>
  
 
</syntaxhighlight>شيفرة CSS:<syntaxhighlight lang="css">
 
</syntaxhighlight>شيفرة CSS:<syntaxhighlight lang="css">
سطر 105: سطر 107:
 
}
 
}
 
</syntaxhighlight>سنستخدم في المثال الآتي الخاصية <code>border-radius</code> مع أربع قيم لإعطاء العنصر <code>[[HTML/div|<nowiki><div></nowiki>]]</code> شكل الحرف D، تذكّر أنَّ أوّل قيمة تمثِّل الركن العلوي الأيسر، وثاني قيمة هي الركن العلوي الأيمن، وثالث قيمة هي الركن السفلي الأيمن، ورابع قيمة هي الركن السفلي الأيسر:<syntaxhighlight lang="html">
 
</syntaxhighlight>سنستخدم في المثال الآتي الخاصية <code>border-radius</code> مع أربع قيم لإعطاء العنصر <code>[[HTML/div|<nowiki><div></nowiki>]]</code> شكل الحرف D، تذكّر أنَّ أوّل قيمة تمثِّل الركن العلوي الأيسر، وثاني قيمة هي الركن العلوي الأيمن، وثالث قيمة هي الركن السفلي الأيمن، ورابع قيمة هي الركن السفلي الأيسر:<syntaxhighlight lang="html">
<div>the border will curve into a 'D'</div>
+
<div>D الحد سينحني على شكل حرف</div>
 
</syntaxhighlight>شيفرة CSS:<syntaxhighlight lang="css">
 
</syntaxhighlight>شيفرة CSS:<syntaxhighlight lang="css">
 
div {
 
div {
سطر 141: سطر 143:
  
 
== البنية العامة ==
 
== البنية العامة ==
تُحدَّد قيمة الخاصية <code>border-radius</code> كما يلي:
+
تُحدَّد الخاصية <code>border-radius</code> كما يلي:
 
* قيمة وحيدة أو قيمتين أو ثلاث أو أربع قيم من القيم الطولية <code>[[CSS/length|<length>]]</code> أو النسب المئوية <code>[[CSS/percentage|<percentage>]]</code>، وذلك لتحديد نصف قطر وحيد للأركان.
 
* قيمة وحيدة أو قيمتين أو ثلاث أو أربع قيم من القيم الطولية <code>[[CSS/length|<length>]]</code> أو النسب المئوية <code>[[CSS/percentage|<percentage>]]</code>، وذلك لتحديد نصف قطر وحيد للأركان.
 
* يمكن أن يُتبَع ما سبق بالمحرف <code>/</code> ويليه قيمة أو قيمتين أو ثلاث أو أربع قيم طولية <code>[[CSS/length|<length>]]</code> أو نسب مئوية <code>[[CSS/percentage|<percentage>]]</code>، وذلك لتحديد نصف قطر ثانوي للتدوير لكي نحصل على أركان مدورة على شكل قطع ناقص.
 
* يمكن أن يُتبَع ما سبق بالمحرف <code>/</code> ويليه قيمة أو قيمتين أو ثلاث أو أربع قيم طولية <code>[[CSS/length|<length>]]</code> أو نسب مئوية <code>[[CSS/percentage|<percentage>]]</code>، وذلك لتحديد نصف قطر ثانوي للتدوير لكي نحصل على أركان مدورة على شكل قطع ناقص.
سطر 172: سطر 174:
 
</syntaxhighlight>
 
</syntaxhighlight>
  
=== القيمة <code>[[CSS/length|<length>]]</code> أو <code>[[CSS/percentage|<percentage>]]</code> ===
+
=== <code>[[CSS/length|<length>]]</code> أو <code>[[CSS/percentage|<percentage>]]</code> ===
 
تحديد طول نصف قطر الدائرة أو أنصاف القطرين الرئيسي والثانوي في القطع الناقص، ويمكن استخدام الأطوال المطلقة بما يسمح به نوع البيانات <code>[[CSS/length|<length>]]</code>، والنسب المئوية للقطر الرئيسي (الأفقي) تكون نسبةً إلى عرض صندوق العنصر، والنسب المئوية للقطر الثانوي (الرأسي) تكون نسبةً إلى ارتفاع صندوق العنصر. ولا يجوز استخدام القيم السالبة.
 
تحديد طول نصف قطر الدائرة أو أنصاف القطرين الرئيسي والثانوي في القطع الناقص، ويمكن استخدام الأطوال المطلقة بما يسمح به نوع البيانات <code>[[CSS/length|<length>]]</code>، والنسب المئوية للقطر الرئيسي (الأفقي) تكون نسبةً إلى عرض صندوق العنصر، والنسب المئوية للقطر الثانوي (الرأسي) تكون نسبةً إلى ارتفاع صندوق العنصر. ولا يجوز استخدام القيم السالبة.
  
سطر 182: سطر 184:
 
<length-percentage> = <length> | <percentage>
 
<length-percentage> = <length> | <percentage>
 
</syntaxhighlight>
 
</syntaxhighlight>
 
+
==انظر أيضًا==
 +
*الخاصيات الأخرى التي تضبطها الأركان المدورة <code>[[CSS/border-radius|border-radius]]</code>  وهي: <code>[[CSS/border-bottom-right-radius|border-bottom-right-radius]]</code>، و <code>[[CSS/border-bottom-left-radius|border-bottom-left-radius]]</code>، و <code>[[CSS/border-top-left-radius|border-top-left-radius]]</code>، و <code>[[CSS/border-top-right-radius|border-top-right-radius]]</code>.
 +
*صفحة الخاصية <code>[[CSS/border|border]]</code> والخاصيات الأخرى التي تضبطها وهي: <code>[[CSS/border-style|border-style]]</code>، و <code>[[CSS/border-color|border-color]]</code>.
 +
*صفحة الخاصيات التي تضبط أجزاءً من الإطار: الإطار العلوي <code>[[CSS/border-top|border-top]]</code>، والإطاري السفلي <code>[[CSS/border-bottom|border-bottom]]</code>، والإطار اليميني <code>[[CSS/border-right|border-right]]</code>، والإطار اليساري <code>[[CSS/border-left|border-left]]</code>.
 
== مصادر ومواصفات ==
 
== مصادر ومواصفات ==
 
* مواصفة [https://drafts.csswg.org/css-backgrounds-3/#border-radius CSS Backgrounds and Borders Module Level 3].  
 
* مواصفة [https://drafts.csswg.org/css-backgrounds-3/#border-radius CSS Backgrounds and Borders Module Level 3].  
[[تصنيف:CSS]]
+
[[تصنيف:CSS|{{SUBPAGENAME}}]]
[[تصنيف:CSS Property]]
+
[[تصنيف:CSS Property|{{SUBPAGENAME}}]]
[[تصنيف:CSS Border]]
+
[[تصنيف:CSS Border|{{SUBPAGENAME}}]]

المراجعة الحالية بتاريخ 18:49، 22 يوليو 2018

الخاصية border-radius في CSS تسمح لمطوري الويب بتعريف طريقة تدوير أركان الإطار، ويمكن تحديد قيمة واحدة لجعل الأركان دائريةً، أو قيمتين لجعلها على شكل قطع ناقص.

بطاقة الخاصية

القيمة الابتدائية لكل قيمة مختصرة:
تُطبَّق على جميع العناصر.
قابلة للوراثة لا
قابلة للتحريك نعم
النسب المئوية نسبة من البُعد الموافق للقيمة من إطار العنصر.
القيمة المحسوبة لكل قيمة مختصرة:
/* ضبط التدوير لجميع الأركان معًا */
border-radius: 10px;

/* top-left-and-bottom-right | top-right-and-bottom-left */
border-radius: 10px 5%;

/* top-left | top-right-and-bottom-left | bottom-right */
border-radius: 2px 4px 2px;

/* top-left | top-right | bottom-right | bottom-left */
border-radius: 1px 0 3px 4px;

/* يمكن ضبط قيمتين معًا للتدوير، واحدة لتحديد نصف القطر الرئيسي للقطع الناقص، والأخرى لضبط نصف القطر الثانوي له. */
/* (first radius values) / radius */
border-radius: 10px 5% / 20px;

/* (first radius values) / top-left-and-bottom-right | top-right-and-bottom-left */
border-radius: 10px 5% / 20px 30px;

/* (first radius values) / top-left | top-right-and-bottom-left | bottom-right */
border-radius: 10px 5px 2em / 20px 25px 30%;

/* (first radius values) / top-left | top-right | bottom-right | bottom-left */
border-radius: 10px 5% / 20px 25em 30px 35em;

/* القيم العامة */
border-radius: inherit;

يمكن أن يكون الركن دائري الشكل، أو يمكن أن يكون على شكل قطع ناقص (ellipse) وذلك اعتمادًا على القيمة المُسنَدة إلى هذه الخاصية، وإذا كانت القيمة تساوي 0 فلن يكون الركن مدورًا.

لن يتم تطبيق الخاصية border-radius على عناصر الجداول إذا كانت قيمة الخاصية border-collapse مضبوطةً إلى القيمة collapse.

سيتم اقتصاص الخلفية background (سواءً كانت صورةً أو لونًا) عند الإطار (حتى لو كان مدورًا)، لكن مكان الاقتصاص المُحدَّد سيُعرَّف وفق قيمة الخاصية background-clip. يجدر بالذكر أنَّ الاقتصاص سوف يتم حتى لو لم يكن هنالك إطارٌ ظاهرٌ للعنصر.

وكما مع جميع الخاصيات مختصرة، لا يمكن توريث القيم المفردة، كما في border-radius:0 0 inherit inherit، وعندئذٍ يجب استخدام الخاصيات الطويلة كلًا على حدة.

أمثلة

مثال عن استخدام قيمة واحدة لتحديد تدوير جميع أركان عناصر <div> التالية، الذي يكون عرض أحدها مساويًا لطوله، والآخر مستطيل الشكل:

<div class="square border-radius-50">border-radius: 50%</div>

<div class="rectangle border-radius-50">border-radius: 50%</div>

شيفرة CSS:

div {
  background-color: salmon;
  padding: 1em;
  margin: 1em;
  text-align: center;
  color: white;
  line-height: 12em;
  height: 12em;
}
.square {
  width: 12em;
}

.rectangle {
  width: 8em;
}

.border-radius-50 {
  border-radius: 50%;
}

مثال عن تدوير أركان أحد العناصر مع تحديد إطار border له:

<div>إطار سميك مع خاصية تدوير الإطار</div>

شيفرة CSS:

div {
  background-color: salmon;
  color: white;
  padding: 2em;
  margin: 2em;
  border: thick solid #006699;
  border-radius: 20px;
}

سنستخدم في المثال الآتي الخاصية border-radius مع أربع قيم لإعطاء العنصر <div> شكل الحرف D، تذكّر أنَّ أوّل قيمة تمثِّل الركن العلوي الأيسر، وثاني قيمة هي الركن العلوي الأيمن، وثالث قيمة هي الركن السفلي الأيمن، ورابع قيمة هي الركن السفلي الأيسر:

<div>D الحد سينحني على شكل حرف</div>

شيفرة CSS:

div {
  padding: 2em;
  margin: 2em;
  border: solid 10px;
  border-radius: 10px 40px 40px 10px;
}

مثال عن استخدام ثماني قيم مع الخاصية border-radius لجعل تدوير الأركان على شكل قطع ناقص:

<div>border-radius: 10px 40px 40px 10px / 45px 10px 10px 45px;</div>

شيفرة CSS:

div {
  padding: 2em;
  margin: 2em;
  border: solid 10px;
  border-radius: 10px 45px 45px 10px / 45px 10px 10px 45px;
}

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

الميزة Chrome Firefox Internet Explorer Opera Safari
الدعم الأساسي 5 4 9 11.5 5

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

تُحدَّد الخاصية border-radius كما يلي:

  • قيمة وحيدة أو قيمتين أو ثلاث أو أربع قيم من القيم الطولية <length> أو النسب المئوية <percentage>، وذلك لتحديد نصف قطر وحيد للأركان.
  • يمكن أن يُتبَع ما سبق بالمحرف / ويليه قيمة أو قيمتين أو ثلاث أو أربع قيم طولية <length> أو نسب مئوية <percentage>، وذلك لتحديد نصف قطر ثانوي للتدوير لكي نحصل على أركان مدورة على شكل قطع ناقص.

هذا تفصيل عدد القيم التي تقبلها هذه الخاصية:

  • عند تحديد قيمة واحدة، فستُطبّق على جميع الأركان.
  • عند تحديد قيمتين، فأوّل قيمة هي نصف القطر المُطبَّق على الركنين العلوي الأيسر والسفلي الأيمن، والقيمة الثانية على الركنين العلوي الأيمن والسفلي الأيسر.
  • عند تحديد ثلاث قيم، فأوّل قيمة ستُطبّق على الركن العلوي الأيسر، والقيمة الثانية على الركنين العلوي الأيمن والسفلي الأيسر، والقيمة الثالثة على الركن السفلي الأيمن.
  • عند تحديد أربع قيم، فستُطبّق القيم على الركن العلوي الأيسر، والركن العلوي الأيمن، والركن السفلي الأيمن، والركن السفلي الأيسر على التوالي وبالترتيب (أي نبدأ من الركن العلوي الأيسر ثم ندور مع اتجاه عقارب الساعة).

وإذا استخدمنا الخط المائل / فستقبل الخاصية border-radius ثماني قيم، ويكون ما قبل الخط المائل كما بيّنا سابقًا، وأما ما بعده فيُحدِّد نصف القطر الثانوي (الرأسي) للقطع الناقص، ويقبل قيمة واحدة أو قيمتين أو ثلاث أو أربع قيم وهي تماثل ما شرحناه سابقًا من ترتيب.

يمكن توضح ما سبق بأمثلة:

border-radius: 1em/5em;

/* القاعدة السابقة تكافئ ما يلي */

border-top-left-radius:     1em 5em;
border-top-right-radius:    1em 5em;
border-bottom-right-radius: 1em 5em;
border-bottom-left-radius:  1em 5em;

مثال آخر:

border-radius: 4px 3px 6px / 2px 4px;

/* القاعدة السابقة تكافئ ما يلي */

border-top-left-radius:     4px 2px;
border-top-right-radius:    3px 4px;
border-bottom-right-radius: 6px 2px;
border-bottom-left-radius:  3px 4px;

<length> أو <percentage>

تحديد طول نصف قطر الدائرة أو أنصاف القطرين الرئيسي والثانوي في القطع الناقص، ويمكن استخدام الأطوال المطلقة بما يسمح به نوع البيانات <length>، والنسب المئوية للقطر الرئيسي (الأفقي) تكون نسبةً إلى عرض صندوق العنصر، والنسب المئوية للقطر الثانوي (الرأسي) تكون نسبةً إلى ارتفاع صندوق العنصر. ولا يجوز استخدام القيم السالبة.

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

border-radius: <length-percentage>{1,4} [ / <length-percentage>{1,4} ]? ;

حيث:

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

انظر أيضًا

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