الجداول Tables
تسجيل الدخول
تنسيق وتصميم الجداول بإستخدام لغة CSS
تستخدم الجداول عادةً لعرض البيانات المجدولة ، مثل التقارير المالية.
ولكن عندما تقوم بإنشاء جدول HTML بدون أي أنماط أو سمات ، فإن متصفحات الويب سوف تعرضها بدون أي حدود. بإستخدام خصائص لغة CSS يمكننا تحسين مظهر الجداول بشكل كبير.
توفر لغة CSS العديد من الخصائص التي تسمح لنا بالتحكم في تخطيط وعرض عناصر الجدول. في هذا الدرس سوف نتعلم كيفية استخدام لغة CSS لإنشاء جداول أنيقة ومتسقة.
إضافة الحدود للجداول
إن الخاصية border من لغة CSS هي أفضل طريقة لإضافة حدود للجداول.
في المثال التالي سنقم بإضافة حد أسود لعناصر <table> و <th> و <td>.
- table, th, td {
- border: 1px solid black;
- }
بشكل افتراضي ، يرسم متصفح الويب حدًا حول الجدول ، وكذلك حول جميع الخلايا ، مع بعض المسافة بينهما ، مما يؤدي إلى حد مزدوج. للتخلص من مشكلة الحدود المزدوجة هذه ، يمكنك ببساطة دمج حدود خلايا الجدول المجاورة وجعل الحدود خطا واحدا فقط.
دعنا نلقي نظرة على الرسم التوضيحي التالي لفهم كيفية تطبيق الحدود على الجدول.
دمج حدود الجداول
كما لاحظنا من الرسم التوضيحي السابق الشكل الافتراضي لحدود الجدول هي الحدود المزدوجة لكل خلية من خلايا الجدول حدودها المميزة الخاصة بها.
. باستخدام الخاصية border-collapse من لغة CSS يمكننا دمج حدود الجدول بحيث تشترك خلايا الجدول المجاورة في حد مشترك.
لنجرب المثال التالي لفهم كيفية عمل الخاصية border-collapse :
- table {
- border-collapse : collapse;
- }
- table , th, td {
- border : 1px solid black;
- }
يمكننا أيضًا إزالة المسافة بين حدود خلايا الجدول من خلال الخاصية border-spacing من لغة CSS مع القيمة 0. ومع ذلك ، فإنها تزيل المساحة فقط ولكن لا تقوم بدمج الحدود كما هو الحال عندما نقوم بإستخدام الخاصية border-collapse مع القيمة collapse.
تعديل المساحة داخل الجداول
بشكل افتراضي ، ينشئ متصفح الويب خلايا الجدول كبيرة بما يكفي لاحتواء البيانات في داخلها.
لإضافة مساحة أكبر بين محتويات خلية الجدول وحدود الخلية ، يمكنك ببساطة استخدام الخاصية padding من لغة CSS.
لنجرب المثال التالي ونرى كيفة عملها:
- th, td {
- padding : 15px;
- }
يمكننا أيضًا ضبط التباعد بين حدود الخلايا باستخدام الخاصية border-spacing من لغة CSS ، إذا كانت حدود الجدول غير مدمجة (بالشكل الافتراضي).
لنجرب المثال التالي ونرى كيفة عملها
- table {
- border-spacing : 10px;
- }
تحديد عرض وارتفاع الجدول
بشكل افتراضي ، سيتم عرض الجدول بشكل عريض وطويل بما يكفي لاحتواء كافة محتوياته.
ومع ذلك ، يمكنك أيضًا تحديد عرض الجدول وارتفاعه وكذلك خلاياه بشكل صريح باستخدام الخاصية width و الخاصية height من لغة CSS.
في المثال التالي سنقوم بتحديد عرض الجدول ب 100٪ ، وارتفاع الخلايا العنوانية th ب 40 بكسل.
- table {
- width : 100%;
- }
- th {
- height : 40px;
- }
التحكم في شكل الجدول النهائي
يتوسع الجدول ويتقلص لاستيعاب البيانات الموجودة بداخله. هذا هو السلوك الافتراضي. مع امتلاء البيانات داخل الجدول ، تستمر في التوسع طالما هناك مساحة. ومع ذلك ، في بعض الأحيان ، من الضروري تعيين عرض ثابت للجدول من أجل التحكم في الشكل النهائي للجدول.
يمكنك القيام بذلك بمساعدة الخاصية table-layout من لغة CSS. تحدد هذه الخاصية الخوارزمية التي سيتم استخدامها لعرض الجدول بالشكل النهائي (خلايا الجدول والصفوف والأعمدة). تأخذ هذه الخاصية واحدة من قيمتين:
auto- باستخدام هذه القيمة سيتم تعديل عرض الجدول وخلاياه لتناسب المحتوى. هذه هي القيمة الافتراضية.fixed- باستخدام هذه القيمة ، لا يعتمد شكل الجدول النهائي على محتوى الخلايا ؛ يعتمد فقط على عرض الجدول وعرض الأعمدة والحدود أو تباعد الخلايا. عند استخدام هذه القيمة عادة ما يكون عرض الجدول داخل المتصفح أسرع من استخدام القيمةauto.
في المثال التالي سنقوم باستخدام القيمة fixed للخاصية table-layout وسنقوم بتحديد عرضه ب 300 بكسل.
- table {
- width : 300px;
- table-layout : fixed;
- }
يمكننا تحسين أداء عرض الجدول من خلال تحديد القيمة fixed لخاصية table-layout. تؤدي القيمة fixed لهذه الخاصية إلى عرض تسريع الجدول داخل متصفح الويب وذلك بعرض الصفوف واحد تلو الاخر ، مما يوفر للمستخدمين المعلومات بوتيرة أسرع.
بدون استخدام القيمة fixed للخاصية table-layout في الجداول الكبيرة ، لن يرى المستخدمون أي جزء من الجدول حتى يقوم المتصفح بمعالجة الجدول بأكمله.
محاذاة النص داخل خلايا الجدول
يمكنك محاذاة محتوى النص داخل خلايا الجدول إما أفقيًا أو رأسيًا.
المحاذاة الأفقية لمحتويات الخلية
للمحاذاة النص افقيا داخل خلايا الجدول ، يمكنك استخدام الخاصية text-align بنفس الطريقة المستخدمة مع العناصر الأخرى. والقيم لهذه الخاصية هي left و right و center و justify.
في المثال التالي سنقوم بمحاذاة النص داخل عناصر <th> إلى اليسار.
- th {
- text-align : left;
- }
تتم محاذاة النص الموجود داخل عناصر <td> بشكل افتراضي إلى اليسار ، بينما تكون محاذاة النص الموجود داخل عناصر <th> إلى الوسط ويظهر بخط غامق بشكل افتراضي.
المحاذاة الرأسية لمحتويات الخلية
وبالمثل ، يمكننا محاذاة محتوى الخلايا رأسيًا داخل عنصري <th> و <td> بإستخدام القيم top أو bottom أو middle للخاصية vertical-align من لغة CSS. القيمة الافتراضية لهذه الخاصية هي middle .
في المثال التالي سنقوم بمحاذاة النص داخل عناصر <th> رأسيًا إلى الاسفل.
- th {
- height : 40px;
- vertical-align : bottom;
- }
التحكم في موضع عنوان الجدول Table Caption
يمكننا تحديد موضع عنوان الجدول (تسمية الجدول) باستخدام الخاصية caption-side من لغة CSS.
يمكننا وضع عنوان الجدول إما في أعلى أو أسفل الجدول. الموضع الافتراضي هو في الأعلى.
- caption {
- caption-side : bottom;
- }
لتغيير المحاذاة الأفقية لنص عنوان الجدول (على سبيل المثال إلى اليسار أو اليمين) ، يمكننا ببساطة استخدام الخاصية text-align من لغة CSS ، كما نتعامل مع النص العادي.
التعامل مع الخلايا الفارغة في الجداول
في الجداول التي لها حدود منفصل (الوضع افتراضي) ، يمكننا أيضًا التحكم في عرض الخلايا التي ليس لها محتوى داخل متصفح الويب باستخدام الخاصية empty-cells .
تقبل هذه الخاصية القيمة show او hide. القيمة الافتراضية لهذه الخاصية هي show ، والتي تعرض الخلايا الفارغة مثل الخلايا العادية ، ولكن إذا تم تحديد القيمة ب hide، فلن يتم رسم حدود أو خلفيات حول الخلايا الفارغة. دعنا نجرب مثالًا لفهم كيفية عمله حقًا:
- table {
- border-collapse: separate;
- empty-cells: hide;
- }
إن وضع رمز المسافة داخل خلية الجدول يجعلها غير فارغة. و حتى لو بدت تلك الخلية فارغة ، فإن القيمة hide لن تخفي الحدود والخلفيات.
إنشاء جداول مخططة
يعد تحديد ألوان خلفية مختلفة للصفوف المتعاقبة أسلوبًا شائعًا لتحسين إمكانية قراءة الجداول التي تحتوي على كمية كبيرة من البيانات.
يمكننا ببساطة تحقيق هذا التأثير باستخدام المحدد :nth-child() من نوع المحددات pseudo-class.
في المثال التالي سنقوم بإبراز كل الصفوف الفردية داخل الجدول .
- tbody tr:nth-child(odd) {
- background-color: #f2f2f2;
- }
عادةً ما يشبه الجدول المخطط في المثال السابق الصورة التالية.
جعل الجداول متجاوبة للعرض على اجهزة مختلفة
الجداول وبشكل افتراضي لا تكون متجاوبة للعرض على اجهزة مختلفة. ولدعم الأجهزة المحمولة ، يمكننا إضافة التجاوب لجداولك من خلال اضافة خاصية التمرير الأفقي على الشاشات الصغيرة. وللقيام بذلك سنقوم بإحاطة عنصر الجدول بعنصر <div> وتطبيق النمط overflow-x: auto عليه كما هو مبين في المثال التالي:
- <div style="overflow-x:auto;>
- <table>
- ... table content ...
- </table>
- </div>