-
المساهمات
1311 -
تاريخ الانضمام
-
تاريخ آخر زيارة
-
عدد الأيام التي تصدر بها
166
نوع المحتوى
ريادة الأعمال
البرمجة
التصميم
DevOps
التسويق والمبيعات
العمل الحر
البرامج والتطبيقات
آخر التحديثات
قصص نجاح
أسئلة وأجوبة
كتب
دورات
كل منشورات العضو Mohamad Ibrahim3
-
هذا الملف هو خاص بمُستخدمي النظام، فكل سطر من أسطر هذا الملفّ هي تخصّ مُستخدم وحيد، والمعلومات مقسّمة على شكل حقول يفصل فيما بينها (:)، لنأخذ المثال التّالي: ubuntu:x:1001:1001:Ubuntu:/home/ubuntu:/bin/bash معاني هذه الحقول هي بالترتيب من اليسار إلى اليمين: - اسم المُستخدم username، وهو الاسم المُستخدم للدخول إلى النظام - كلمة المرور و (x) تُشير إلى كلمة المرور مُشفّرة، وهي موجودة في هذا المسار /etc/shadow. - معرّف اسم المُستخدم user id أو UID، والرقم 0 محجوز للمُستخدم root. - معرّف المجموعة group id أو GID. - هذا الحقل خاصّ بإضافة معلومات حول المُستخدم، رُبّما الاسم الكامل أو البريد الإلكترونيّ. - مسار دليل المُستخدم home directory، وعند عدم وجود مسار مُحدّد سيكون المسار هو /. - الطرفيّة المُستخدمة shell.
- 1 جواب
-
- 1
-
يقوم هذا الأمر بتحديث عناوين مُستودعات التحميل الّتي يعتمد عليها النّظام عند طلب تحميل الحِزمة، وعليه فإن عدم تنفيذ هذا الأمر قبل تنصيب الحزمة سيؤدي ربما إلى تحميل حزمة أقدم من الإصدار المتوفّر من الحِزمة المطلوبة، ولذلك تجد العديد من الشروحات هنا في الأكاديميّة تطلّب تنفيذ هذا الأمر، وذلك بهدف تنصيب آخر إصدار من الحزمة المطلوبة، كما يُمكن الوصول إلى قائمة عناوين المُستودعات في أبونتو: في الملفّ التّالي: /etc/apt/sources.listأيضًا في المسار التّالي: /etc/apt/sources.list.d
-
إنّ كان هدفك تعلم لغة البرمجة من أجل برمجة مواقع الإنترنت فأنصحك بتعلم لغة روبي، ففي رأي أن مُجتمع لغة Ruby في هذا المجال مُتفوّق على مُجتمع Python، ولكن إن أردت لغة برمجة عامّة فلغة Python ربما هي الخيار الأنسب وخاصّة في المجال الأكاديمي، في جميع الأحوال أيًا كان اختيارك فلن تكون مخطئًا فاللغتان تستطيع عمل بهما ما أردت، يعني لن تكون مخطئًا في اختيارك في أي منهما، بالتوفيق.
- 2 اجابة
-
- 1
-
عندما تجري اختبارات على الشيفرة الخاصّة بك ستجد أنّ بعض الكائنات (objects) صعبة الاختبار، أو ربما أنها مكلفة في الاختبار (ربما اتصال مع موقع آخر، أو إرسال بريد إلكتروني) لهذا الغرض يتمّ اللجوء لهذا النوع من الأسلوب، فكل ما تفعله هو إنشاء كائن زائف عند الاختبار ليحل محل الكائن الحقيقي ليعود لك بالنتيجة المُتوقعة، هذه المُصطلحات ستجدها بأسماء مُختلفة وعلى حسب لغة البرمجة الّتي تستخدمها، فقد تجدها بالاسم doubles أو dummies. باعتبار أنك في بداية الطريق، فلا تقلق من عدم فهمك لهذه الأمور، فهي مُتقدّمة نوعًا ما، أنصحك بالتركيز على الأساسيات.
-
يُمكن القول لتسريع أي موقع في المُجمل (الأمر شائك في التفاصيل) كل ما عليك فعله هو التقليل من عدد وحجم الطلبات المُرسلة بين المُتصفّح إلى السيرفر/الخادم، ويتم ذلك عبر جملة من المُمارسات: -جمع combine ملفّات .js وملفات .css فتحميل ملفّ جافا سكريبت كبير الحجم أسرع من تحميل ملفّات جافا سكريبت صغيرة ومجزّئة، وبالتالي يُنصح دئمًا بأن يكون هناك ملفّ ّ .js واحد وملف .css واحد لكامل الموقع. -التقليل من استخدام @import في ملفّات css، فكل سطر منها يتطلّب طلب خاصّ به ولا تُحمّل دفعة واحدة. -اجمع صور الموقع بصورة واحدة وذلك باستخدام تقنية image sprites، فكل صورة تحتاج طلب خاص بها، يعني سيكون لديك صورة كبيرة تحتوي مجموعة صور الموقع، وتوزيع هذه الصور يتمّ عبر CSS. -استخدم تقنيّات التقليل minify مع ملفّات جافا سكريبت وملفات css، أيضًا والضغط compression باستخدام gzip -استخدم خدمات CDN.
-
بإمكانك معرفة ذلك عبر إجراء تقييم ذاتي، في الحقيقة هناك قائمة من الأسئلة كنت قد قرأتها في أحد المُدونات المُختصّة بالعمل الحرّ، الإجابة على هذه الأسئلة بنعم في مُعظمها يمتحك فرصة قويّة بأن تكون مُستقل ناجح: -هل أنت شخص قادر على تحفيز نفسك بنفسك؟ في العمل الحر لن يجبرك أحد على الاستيقاظ صباحًا فلا يوجد مُراقب دوام، فأنت هو المُراقب والمُوظّف بنفس الوقت، أيضًا التعليم أنت مُطالب دائمًا بتطوير نفسك وتعلّم جديد ميدانك، فلن يطلب منك أحد أن تفعل ذلك. -هل لديك مهارات إدارة الوقت؟ صحيح أن من ميزات العمل الحر العمل في أي وقت وفي أي مكان، ولكن لهذه الميزة مشكلة، وهي أنّك عرضة للتشتّت بين الحين والآخر، ولذلك عليك الالتزام بجدول مُحدّد والعمل دائمًا ضمن هذا الجدول. -هل صاحب مُبادة؟ لن يخبرك أحد بالخطوة التّالية، أنت المُدير وأنت المُوظّف. -هل تملك مهارات التواصل؟ التواصل مع العميل هو كل شيء، بل هو أساس النجاح مع العمل الحرّ، قم بقراءة ترجمتي لأحد مقالات العمل الحرّ هنا على الأكاديميّة، رُبما توضّح لك ما أقصده بهذه النقطة بالذات، وهي بعنوان " عندما لا يرضى العميل عن عملك" -هل أنت قادر على تقبّل التغيير؟ ربما أنت مطوّر مواقع، قد تضطر إلى العمل بالكتابة التقنيّة أو الترجمة، فقد لا يتوفّر لك دائمًا مشروع برمجي لكي تعمل عليه. أيضًا قم بقراءة المقالة التّالية "الأدوات والخطوات اللّازمة لانطلاقة صحيحة في عالم العمل الحر"
-
يجب للشركة أن تضع لنفسها أهدف طويلة الأمد، يجب أيضًا على الشركة أن يكون لها مُهمّة معنويّة أساسيّة لا تحيد عنها وهي أشبه بالبوصلة الّتي توجّه فريق العمل نحو اتخاذ القرار الصحيح، مثلًا في شركة "حسوب" المُهمّة الأساسيّة هي "تطوير الويب العربي"، هذا هي البوصلة الّتي سوف ينظر إليها فريق العمل عند اتخاذ القرارات الصغيرة والكبيرة، يعني لا تجعل أهداف فريق العمل هو الماديّات فقط، فهي ليست كل شيء، والمعنويات قد تفتح بابًا للماديّات، ازرع هذه الثقافة في فريق العمل وستحصل على نتائج مُرضية، قم بُمراجعة هذا المقال على الأكاديميّة وهو بعنوان "لماذا تحتاج الشركات الناشئة إلى تحديد رؤية بعيدة المدى"، اقرأ أيضًا مقالة بعنوان "كيف تجذب الموهوبين إلى شركتك النّاشئة وتُكوّن فريق عمل من المتميزين".
-
اختيار السعر المُناسب يتطلّب بعض الخبرة ودراسة للسوق المُستهدف، ولكن هناك بعض الأساليب الّتي من شأنها المُساعدة في الحصول على نتائج مُرضية لجميع الأطراف، فبإمكانك مثلًا تحديد شرائح مُختلفة في التسعير، فمثلًا شريحة خاصّة بالطلاب، شريحة خاصّة بالشركات، شريحة خاصّة بالأفراد، فالكل شريحة لها سعر مُختلف عن الآخر، وبذلك لن تضطر إلى تحديد سعر وحيد يشمل جميع الأطراف، أيضًا قم بقراءة بعض المقالات هنا في الأكاديميّة متعلّقة بمسألة التسعير وحاول الخلط والمزج بين هذه الأساليب لتحصل على التوليفة المناسبة لمشروعك، كهذه المقالة "مالم يخبرك به علماء النفس عن تسعير المنتجات"، أيضًا "التسعير المثالي = أرباح أكبر من مبيعات أقل؟"
-
يختلف الكثير حول هذه النقطة، ولكن في المُجمل أغلب روّاد الأعمال تميل إلى تنفيذ الفكرة بأقل ميزات مُمكنة والتركيز على جوهر الفكرة والّتي لا يُمكن للتطبيق أنّ يكون بدونها، وبعد اختبار جودة ونجاح الفكرة وتحقيقها للعوائد المطلوبة، عندئذ من المُمكن التركيز على الكماليات، فأنت في هذه المرحلة تحاول الحصول على feedback لجودة الفكرة والّتي من شأنها تحدّد مُستقبل المشروع، لتوضيح الكفرة بشكل أكبر أنصحك بقراءة مقال بعنوان "تعريف Minimum Viable Product مع نموذج عملي" هنا على الأكاديمية والذي سينوّر لك الطريق في اختيار الطريق الأنسب لمشروعك، بالتوفيق.
- 1 جواب
-
- 1
-
الفكرة ليست في كيفيّة قولك لا، يعني إنّ قلتها بلباقة أو بأسلوب آخر لا يهم، فالمشكلة لم تحل، فطلب العميل لاختبارك هو شيء طبيعي، وربما لو كنت أنت مكان صاحب المشروع لفعلت نفس الشيء، مع ذلك يجب التركيز على نقطة هامّة، وهي صفحة الأعمال (portfolio) سواء الموجودة على منصة العمل الحرّ نفسها، أو صفحتك الخاصّة بأعمالك، يجب عليك الاهتمام بها أكثر، اعرض جميع أعمالك الصغيرة والكبيرة، ربما صاحب المشروع قد اطلع على صفحة أعمالك لكن لم يجد عمل مُرتبط مع المشروع الذي هو بصدد توظيفك من أجله، ممّا جعله أن يطلب هذا الاختبار، لذلك حاول الاهتمام في هذه النفطة فهي نقطة جوهريّة، فعندما تقدّم على عرض ما حاول إبراز أعمالك السابقة والمُرتبطة بهذا المشروع، وتذكّر أن على الأعمال المنشورة أن تكون واضحة أنّها من عملك ولا تجعل الأمور غامضة ومحل تساؤل، ولا تقم فقط بذكر العمل، ضع روابط، اذكر الشهادات الّتي تلقيتها من أصحاب هذه الأعمال، كل هذا من شأنه أن يساعد على الحدّ من هذا النوع من الطلبات، راجع هذا الرابط على الأكاديمية سوف يُساعدك في تحديث صفحة أعمالك "نصائح لإنشاء معرض أعمال جذاب"
-
تعمل العمليات بمُستخدم مُحدّد وبصلاحيات مُحدّدة، كما أشار الأخ مُحمّد، فبعض العمليات الأساسية للنظام تطلب صلاحيات وصول عالية (root access) كالعلميات الّتي تحتاج الوصول إلى ملفّات النظام، ولا تستطيع العمل بدون هذه الصلاحيات، ولكن هناك بعض العمليات الّتي تبدأ بالعمل بصلاحيات عالية، ومن ثم تبدأ بإنتاج عمليات تعمل بصلاحيات أقل وذلك للتقليل من خطورة هذه العمليات، فالخادم أباتشي مثلًا يبدأ بصلاحيات عالية root والتي تسمح له باستخدام المنفذ 80، بعد ذلك سيُنتج عمليات بصلاحيات وصول أقل لاستكمال عمله بدون الإضرار بالنظام عادةً تكون هذه العمليّات تتم بصلاحيات المُستخدم ذو الاسم apache أو www-data.
-
لتخصيص الطرفيّة عليك بتخصيص الشيل (shell) وهي بشكل افتراضيّ Bash، وهي كافية وتستطيع عمل كل شيء بها، ولتخصيصها عليك كتابة بعض الإعدادات في الملفّ .bashrc أو .bash_profile، ولكن هناك أطر عمل تقدّم لك إعدادات مُسبقة تستطيع الاستفادة منها أشهرها الإطار “bash it”، ولكن في مرحلة لاحقة ستجد إن “Bash” يفتقر إلى بعض الميزات وهنا سوف تستخدم “z-shell” وهي تملك ميزات أكثر وقدرة على التخصيص بشكل كبير، كما أنّ لها إطار عمل مشهور جدًّا وهو “oh-my-zsh” والذي يملك إضافات وقوالب (themes) لا تعد ولا تحصى، والّتي ستجعل من سطر الأوامر مُختلف ومُتقدّم جدًّا.
-
للتعلّم أي شيء عليك باستخدامه، نظام التشغيل لينكس كواجهة سهل جدًّا وهو مُماثل لنظام التشغيل ويندوز إلى حدّ كبير، ما يجب التركيز عليه هو الطرفيّة والّتي سوف تعلّمك كيفية تنفيذ الأوامر وتوضّح لك فلسفة لينكس والمنهجيّة الّتي يتبعها، نصيحتي لك إن كنت تستخدم نظام التشغيل ويندوز أنّ تقوم بتنصيب أحد برمجيات الأنظمة الوهميّة مثل VirtualBox فهو مجاني وسهل الاستخدام، بعد ذلك ابدأ بتحدي نفسك بتجربة كل يوم شيء جديد على النّظام، كيف تُنشئ المُجلدات والملفّات مع صلاحيّات، كيف تُدير المُستخدمين، كيف تنصب البرمجيات، إنشاء خوادم محليّة وتجربتها وإليه من هذه الأمور، لتجد نفسك بعد فترة أنك قادر على استخدام الطرفيّة بسهولة وبدون عناء، بعد ذلك عليك بالقدوم إلى هنا للتصفّح قسم إدارة الخوادم ستجد أنك أصبحت تستمتع بقراءة هذه المقالات، قد ينصحك البعض بتنصيب لينكس كنظام ثانوي بجانب النّظام الحالي، من تجربتي الشخصيّة هذا لن يُساعدك، لأنك ستجد نفسك دائمًا ميال لاختيار نظام التشغيل ويندوز عند الإقلاع، ولكن مع النّظام الوهميّ يُصبح الانتقال بين النظامين أسهل وسوف تتعلّم النّظام بأقل جهد مُمكن.
- 1 جواب
-
- 1
-
تحسين مُستوى الكتابة يتطلّب منك القراءة المُستمرة، يعني يجب عليك أنّ تكون قارئ نهمًا، فالقراءة أفضل وسيلة لتحسين أسلوب الكتابة، يُمكك إمّا قراءة كتب أدبيّة عامّة، أو حتّى قراءة التدوينات مثل مدوّنة "شبايك" فالمُدوّن رؤوف معروف بأسلوبه الراقي واحترامه لقواعد اللغة العربيّة، ومن أجل الإملاء يُمكنك الاستعانة ببعض الكتب مثل هذا الكُتيّب [من ذا الّذي قدّد البيان؟] فهو كتاب جامع للأخطاء الإملائيّة الشائعة وسوف تستفيد منه لا محالة.
-
شكّل العمل الحرّ نقلة نوعيّة للكثير، وهناك قصص نجاح كثيرة أعرفها لمُستقلين يندمون على أيام الوظيفة، ونعم، يُمكن الاعتماد على العمل الحرّ كدخل أساسي في حياتك ومن دون اللّجوء إلى وظيفة دائمة. ميزات العمل الحرّ: -الحرية، فأنت سيّد نفسك، لا مُدير ولا رقيب. -تنفذ المشروع الّذي تريده وترفض غيره وتختار ما يُناسب إمكانياتك. -تعمل بعدد الساعات الّذي يُناسب، وما يتوافق مع أمور الحياة والدراسة. -عدم التقيّد بمجال مُحدّد، ربما أنت مُبرمج أو مطوّر مواقع، ولكن في نفس الوقت بإمكانك العمل بمجال الكتابة التقنيّة (التدوين)، أو حتّى كتابة الكتب الإلكترونيّة المُتخصّصة. مساوئ العمل الحرّ: -الافتقار إلى الاستمراريّة والثبات -مصاريف تنفيذ المشروع تقع عليك، وتبدأ من أجور الإنترنت وتنتهي إلى أجور شراء تراخيص البرمجيات الّتي تعمل عليها مثل رخصة برنامج فوتوشوب أو رخصة برنامج كوريل وإليه من برمجيات. -لا تأمين صحي، لا تأمين تقاعدي.
-
لا تترك وظيفتك الحاليّة، بل عليك العمل كمُستقل أوّلًا بجانب الوظيفة الحاليّة، هذه الفترة سوف تكسبك الثقة بنفسك من خلال العمل على بعض المشاريع الخفيفة، أيضا تسمح لك هذه الفترة بالتفكير والاختيار إما بالاستمرار أو عدم المُتابعة فربما تكتشف أن العمل الحرّ والعمل كمُستقل لا يناسبك وهو أمر طبيعي، فالعمل الحر لا يُناسب الجميع، الدخول مُباشرةً وبدون تخطيط قد يُسبب لك بعض المشاكل، ويجعلك في حالة من الإحباط، يوجد نصيحة كنت قد سمعتها من أحدهم: "مفتاح النجاح هو التخطيط ومن ثم التخطيط وعند الانتهاء من التخطيط، تبدأ بالتخطيط من جديد".
-
سيخبرك أي رائد أعمال مُتمرّس أنّ الخطوة التّالية يجب أنّ تكون أي شيء ما عدا تنفيذ الفكرة، نعم قد يبدو الأمر مبالغًا به، ولكن أظهرت التجارب أنّ على رائد الأعمال اختبار فكرته قبل التنفيذ، قد يبدو الأمر من الوهلة الأولى مضيعة للوقت، ولكن الوقت المُستثمر في اختبار الفكرة سوف يجني ثماره في المُستقبل، أنت في هذه المرحلة الحاليّة تظن أنّ فكرتك ناجحة وتقدّم قيمة للمُستخدم المُستهدف، وأن فكرتك تحل مُشكلة، لكن السؤال الأهم، هل الفكرة جيّدة بما فيه الكفاية لتجعل المُستخدم يدفع مُقابلها؟ هذه هو السؤال، وستحصل على إجابته في مرحلة "اختبار جودة الفكرة"، استعن بالشبكات الاجتماعيّة، اجري استطلاعًا للرأي، اسأل هنا وهناك، لتحصل في النهاية على الإجابة الشافية قبل الخوض والشروع في التنفيذ.
-
في عالم الأعمال يمكنك الحصول على تمويل بإحدى الطريقتين التّاليتين: إما بالاستدانة Debt Financing أو مُشاركة المُلكيّة Equity Financing، ولكلا الطريقتين محاسن ومساوئ. ما هو Debt Financing: وهو عندما يقوم رائد الأعمال بالاستدانة لدعم مشروعه من أحد الأطراف إما بنك، أو قريب، أو صديق، هذا النوع من التمويل يُمكن الحصول عليه بشكل أسهل مقارنةً مع النوع الثّاني، في التمويل بالاقتراض أنّت مُطالب برد القرض في فترة مُحدّدة، ولكنّك هنا أنت لا تُشارك أرباحك مع أحد، وأنت صاحب القرار الأوّل والأخير. ما هو Equity Financing: وهو عندما يقوم رائد الأعمال بمُشاركة أرباح المشروع (المُستقبليّة) مع المُستثمر مُقابل مبلغ من المال لدعم المشروع، وهنا أنت غير مُطالب برد المال عند الإفلاس -لا سمح الله- فعند الإفلاس أنت مُطالب برد القروض (deft) فقط، أما أموال الاستثمار فهي خسارة يتحملها الطرفين (رائد الأعمال والمُستثمر)، مساوئ هذا النوع من التمويل هو أنك خسرت جزء من مشروعك فنسبة الأرباح سوف تُشاركها مع المُستثمر، قد لا تكون صاحب القرار الأخير في هذا النوع من التمويل (يعتمد الأمر على نسبة وحصّة المُستثمر). في الحقيقة هناك نوع ثالث من التمويل هو التمويل الجماعي Crowd funding والذي بدأ بالانتشار في الآونة الأخيرة.
-
فوائد تسجيل الشركة رسميًّا هي بالمُجمل فوائد قانونيّة، فأنت عندما تسجّل شركتك رسميّا، أنت تعزل نفسك عن المُلاحقة القانونيّة، فعند الإفلاس يتمّ الحجز على أصول الشركة وليس على أموالك الشخصيّة، كما أنّ تسجيل الشركة رسميًّا يُسهل من عمليات الدمج والشراكة بين الشركات عند عمليّات الاستحواذ، أيضًا بتسجيل الشركة رسميًّا أنت تحميها من السرقة الفكريّة، ومن الفوائد أيضًا ضمان حقوق الشركاء فيما بينهم، يجدر الذكر أيضًا أنّ الشركة الرسميّة تعطي انطباع أفضل لدى المُستخدم المستهدف.
- 1 جواب
-
- 1
-
لتعرّب قالب Wordprss أنت بحاجة إلى معرفة أساسيّات HTML و CSS و الأداة Poedit لتسهيل عمليّة الترجمة، ولعمليّة الاختبار بإمكانك العمل على الخادم المحلّي والتجربة بشكل مُباشر إما باستخدام حزمة LAMP على لينكس أو حزمة WAMP على ويندوز، ويُنصح بقراءة التوثيق الرسميّ من الموقع لما يحتويه من نصائح حول دعم اتجاه اللغة (من اليمين إلى اليسار) كما هو موضّح في [1]، تذكّر أنّ تُترجم المعنى والابتعاد عن الترجمة الحرفيّة. [1]: http://codex.wordpress.org/Right-to-Left_Language_Support
-
إن كنت مُبتدئ، ولا تعرف أي شيء عن البرمجة ولغتك الإنكليزية متوسطة أنصحك بالكُتب الخفيفة ذات اللّغة السّهلة والمُبسّطة والابتعاد عن الكُتب المُتقدّمة والمُوجّهة للمُتقدمين، وهي في بعض الأحيان تُعتبر مرجع أكثر من كتاب تعليمي، أنصحك بقراءة هذا الكتاب [JavaScript for Kids]، فهو مُيسّر وذو لغة مُبسّطة ويحتوي على رسومات وصور توضيحيّة، وهو في حدود 300 صفحة، أمّا إن كانت لغتك الإنكليزيّة جيّدة، فأنصحك بهذا الكتاب [Head First JavaScript Programming] وهو بحدود 700 صفحة، كما هناك كتاب لم أقرئه صراحةً، ولكن الكتاب مشهور جدًّا وكاتبه يُعتبر عرّاب لغة جافا سكريبت الكتاب بعنوان [JavaScript The Good Parts]، وهو في حدود 175 صفحة.
- 5 اجابة
-
- 2
-
أفضل لغة برمجة هي اللغة الّتي سوف تبدأ بها، واعلم أنّك عندما تتعلّم أي لغة فانت تتعلّم أساسيات باقي اللغات، واعلم أيضًا أن اللغة الّتي سوف تختارها هي مُجرد أداة لا أكثر، فأنت من سيتحكم باللغة وليس العكس، ابتعد عن المُقارنات بين اللغات ولا تلتفت إليها أبدًا، إن بدأت بتعلّم PHP، ومن ثُمّ أردت تعلّم JavaScript، فلن تقضي بتعلّمها الوقت الّذي قضيته مع لغة PHP، رُبما نصف أو ربع الوقت، ولذلك كل ما عليك هو فقط الاختيار والبدء بالتعلّم.
- 3 اجابة
-
- 1
-
يُساهم إضافة بعض التحريك (animation) عندما تتغيّر أجزاء صفحة الويب، في مُساعدة المُستخدِم على إدراك ما الّذي يحدث في الصّفحة، فيُمكن للتحريك أنّ يَدل على وصول مُحتوى جديد، أو لفت نظره إلى المُحتوى الّذي هو طور الإزالة. ستتناول هذه المقالة كيف يُمكن للتحريك المُساعدة على تقديم مُحتوى جديد، وذلك عبر إظهار وإخفاء عناصر قائمة من القائمة الخاصّة بهم. See the Pen WvjoXa by Walid (@01walid) on CodePen.
-
- 1
-
- إظهار
- تأثيرات حركية
-
(و 3 أكثر)
موسوم في:
-
تمّ التطرّف في الجزء الأوّل من هذا الشرح إلى الخطوات الأوّليّة في بناء صفحة باستخدام إطار عمل 3 Bootstrap، في الجزء الثّاني، سيتم استكمال تصميم الصّفحة بدءًا من الشعار وانتهاءً بذيل الصّفحة. الشعار (Logo) سيتمّ إضافة الشعار إلى رأس الصّفحة كما في التّالي: <header> <a href="/"><img src="images/logo.png" alt="Logo"></a> </header>سيتمّ الاكتفاء بإدراج صورة الشعار وبدون إضافة أية تنسيقات. نموذج البحث سيتمّ الاستفادة من بعض مُكوّنات Bootstrap بغرض إنشاء نموذج البحث، سيتمّ إنشاء نموذج ضمن السطر في رأسيّة الصّفحة، كما سيتمّ إزاحة هذا النموذج إلى جهة اليمين، على أنّ يَملك هذا الحقل الصنف form-control وعنونة (label) وسيحتوي النموذج على المُكوّن (input groups)، ومهمته إزالة الفراغ بين حقل الإدخال النصّي (input text) والزر (button)، كما لو أنّه يقوم بدمجهم كعنصر واحد، ولذلك سيتمّ استخدام الصنف input-group، ولعنصر الإدخال (input) سيتمّ استخدام الصنف form-control ولقسم الزر سيتمّ استخدام الصنف input-group-btn. ومن ثُمّ سيتمّ إضافة الصنف btn-primary للزر، والذي سيمنح الزر لونًا بارزًا وحدودًا بارزةً. <header> ... <form name="search" action="#" method="get" class="form-inline form-search pull-right"> <div class="input-group"> <input class="form-control" id="searchInput" type="text" name="search" placeholder="Search"> <div class="input-group-btn"> <button type="submit" class="btn btn-primary">GO</button> </div> </div> </form> </header>سيتمّ في الخطوة التّالية ضبط عرض صندوق البحث إلى القيمة 200px: body { ... .wrapper { ... header { ... .form-search { width: 200px; } } } }شريط التنقل سيتمّ استخدام مُكوّنات التنقل، والّتي تحتوي على قائمة بالروابط، وسيتم استخدام الصنف navbar-nav لشريط التنقل، والذي يُطبّق تنسيقًا خاصًّا لشريط التنقل. <nav class="navbar navbar-default"> <ul class="nav navbar-nav"> <li><a href="/home/">Home</a></li> <li class="active"><a href="/about/">About us</a></li> <li><a href="/services/">Services</a></li> <li><a href="/partners/">Partners</a></li> <li><a href="/customers/">Customers</a></li> <li><a href="/projects/">Projects</a></li> <li><a href="/careers/">Careers</a></li> <li><a href="/contact/">Contact</a></li> </ul> </nav>كما سيتمّ إضافة هذه المُتغيّرات وذلك بهدف جعل تنسيق شريط التنقل أكثر توافقيّةً مع الصّفحة. /* navigation menu height */ @navbar-height: 37px; /* additional paddings */ @nav-link-padding: 10px 30px; /* background for menu items */ @navbar-default-bg: @panel-bg; /* text color in the menu items */ @navbar-default-link-color: #b2b2b2; /* for the mouse hover - the same color */ @navbar-default-link-hover-color: @navbar-default-link-color; /* background of the active menu item */ @navbar-default-link-active-bg: @brand-primary; /* text color of the active menu item */ @navbar-default-link-active-color: #fff;كما سيتمّ إضافة التعديلات التّالية على ملفّ التنسيق الخاصّ بالمشروع، بغرض تخصيص الخط المُستخدم لشريط التنقل، وذلك بجعل الحروف كبيرة (uppercase)، وضبط نوع وحجم الخط. body { ... .wrapper { ... .navbar a { text-transform: uppercase; font: 14px @brand-font; } } }عنوان الصّفحة (Page Header) سيتمّ استخدام الصنف heading مع عنوان الصّفحة: <div class="heading"> <h1>About us</h1> </div>وبالتنسيق التّالي: body { ... .wrapper { ... .heading { height: 40px; background: transparent url(../images/h1-bg.png); margin: 30px 0; padding-left: 20px; h1 { display: inline-block; color: #7e7e7e; font: normal 40px/40px 'Oswald', sans-serif; background: url(../images/bg.png); margin: 0; padding: 0 10px; text-transform: uppercase; } } } }تمّ في الشيفرة السابقة تعيين صورة خلفية للعنوان (h1)، وتنسيق الخط، ليظهر العنوان بالشكل السابق. القائمة الفرعيّة (Submenu) لن يتمّ استخدام المُكوّن navigation مع القائمة الفرعيّة، حيثُ أنّه لا يناسب التنسيق، بدلًا من ذلك سيتمّ استخدام المُكوّن group list، وكل عنصر من هذا المكوّن سيملك الصنف list-group-item. مع الانتباه أنّ القائمة الفرعيّة يجب توضع داخل الوسم aside: <aside class="col-md-7"> <ul class="list-group submenu"> <li class="list-group-item active">Lorem ipsum</li> <li class="list-group-item"><a href="/donec/">Donec tincidunt laoreet</a></li> <li class="list-group-item"><a href="/vestibulum/">Vestibulum elit</a></li> <li class="list-group-item"><a href="/etiam/">Etiam pharetra</a></li> <li class="list-group-item"><a href="/phasellus/">Phasellus placerat</a></li> <li class="list-group-item"><a href="/cras/">Cras et nisi vitae odio</a></li> </ul> </aside>إن الإعدادات الخاصّة بالمكوّنات تظهر أنّ جميع القوائم المُجمّعة (grouped lists) تستخدم خلفيّة وحدود المكوّن panel: @list-group-bg: @panel-bg; @list-group-border: @panel-inner-border;ومن ثُمّ سيتمّ تطبيق التنسيقات التّالية على القائمة الفرعيّة: body { ... .wrapper { ... .submenu { margin-bottom: 30px; li { display: list-item; font: 300 14px @brand-font; list-style-position: inside; list-style-type: square; padding: 10px; text-transform: uppercase; &.active { color: @brand-primary; } a { color: @text-color; text-decoration: none; &:hover { color: @text-color; } } } } } }تمت إضافة هامش سفلي باستخدام margin-bottom، والتخفيف من حدّة الخط، وتغيير التنسيق الخاصّ بعناصر القائمة باستخدام الخاصّيّة list-style-type لتكون مُربّعة (square)، ومن أجل الروابط تمّ ضبط اللّون، والحروف لتكون حروفًا كبيرةً، الجدير بالذكر هنا أنّ الإشارة & (ampersand) هي جزء من صياغة LESS، والّتي سيتمّ استبدالها بالمُحدّد الأب (parent selector). الشريط الجانبي (Sidebar)سيتمّ إضافة صورة تُشير إلى عنوان مكتب العمل، وذلك أسفل القائمة الفرعيّة. سيتمّ استخدام المُكوّن panel من مكوّنات Bootstrap، وذلك باستخدام الأصناف الفرعيّة منه وهي panel-primary من أجل تلوين العنوان، و يحتوي هذا المكوّن على كتلة علويّة وتستخدم الصنف panel-heading، وكتلة المُحتوى وتستخدم الصنف panel-body، كما سيتمّ استخدام الصنف img-responsive لصورة خريطة الموقع، وذلك من أجل الحصول تجاوبيّة لها على مُختلف قياسات الشاشة (responsiveness). <aside class="col-md-7"> ... <div class="panel panel-primary"> <div class="panel-heading">Our offices</div> <div class="panel-body"> <img src="images/map.png" class="img-responsive" alt="Our offices"> </div> </div> </aside>تمّ بالفعل سابقًا ضبط لون لخلفيّة المكوّن panel وذلك في خصائص Bootstrap وذلك عبر المُتغيّر panel-bg، والآن ما سيتمّ عمله هو تغيير لون الحدود الخاصّة به، وسيتم استخدام اللون الرمادي المُعيّن سابقًا بالمُتغيّر @panel-inner-border: @panel-primary-border: @panel-inner-border;سيتم الحاجة أيضًا إلى تغيير بعض التنسيق الافتراضي للمكوّن panel، وهذه التغييرات لا يُمكن تغييرها بواسطة المُتغيّرات: .panel { box-shadow: none; .panel-heading { font: 14px @brand-font; text-transform: uppercase; padding: 10px; } .panel-body { padding: 10px; } }تمّ في الشيفرة السابقة إزالة الظل الخاصّ بالمكوّن panel وضبط الحشوة padding وضبط الخط. الاقتباس (Quotation)سيتمّ الشروع بالعمل على تصميم المحتوى، وفي البداية سيتمّ إضافة الاقتباس: يشبه هذا الجزء إلى حدٍ كبير المُكوّن Jumbotron، والذي سيتمّ الاستفادة منه هنا، وذلك عبر إضافته داخل عمود المُحتوى (col-md-17): <section class="col-md-17"> <div class="jumbotron"> <blockquote> <p> "Quisque in enim velit, at dignissim est. nulla ul corper, dolor ac pellentesque placerat, justo tellus gravida erat, vel porttitor libero erat." </p> <small>John Doe, Lorem Ipsum</small> </blockquote> </div> </section>باستخدام مُتغيّرات المكوّن jumbotron سيتمّ تعيين اللّون الأبيض للخط، وضبط لون الخلفية إلى قيمة المُتغيّر @brand-primary وهو ذو القيمة #29c5e6: @jumbotron-bg: @brand-primary; @jumbotron-color: #fff;كما سيتمّ إضافة بعض التنسيق: body { ... .wrapper { ... .jumbotron { border-radius: 0; padding: 0; margin: 0; blockquote { border-left: none; p { font: 300 italic 33px @brand-font; text-transform: uppercase; margin-bottom: 0; } small { text-align: right; color: #1D8EA6; font: 300 20px @brand-font; &:before { content: ''; } } } } } }تمّ إزالة الزوايا الدائريّة باستخدام الخاصّيّة border-radius، وتنسيق الخط ليتناسق مع بقيّة التصميم. المُحتوى الرئيسي (Main content) تمّ بالفعل إتمام جميع التنسيقات اللازمة للنص الخاصّ بالمُحتوى، وعليه فإن كل ما يجب عمله هو إضافة ثلاثة فقرات (paragraphs) مع النصّ الخاصّ بها: <p>Lorem ipsum dolor sit amet...</p> <p>Donec vel nisl nibh...</p> <p>Donec vel nisl nibh...</p>سيتمّ في الخطوة التّالية إضافة صورتين، أسفل المُحتوى الكتابي السابق، ولذلك سيتمّ استخدام عمودين: <div class="row"> <div class="col-md-12"> <img src="images/about-1.png" alt="" class="thumbnail"> </div> <div class="col-md-12"> <img src="images/about-2.png" alt="" class="thumbnail"> </div> </div>يُعطي الصنف thumbnail تنسيقًا جميلًا للصور، ومن دون إضافة المزيد من التنسيق، ما سيتمّ عمله فقط هو تعديل الحشوة (padding) ولون الحدود (border): @thumbnail-padding: 1px; @thumbnail-border: #c9c9c9;القسم الخاصّ بفريق العمل أوّلًا، سيتمّ إضافة رأسيّة هذا القسم (header): <h2>Our team</h2>وبالتنسيق التّالي: body { ... .wrapper { ... h2 { background: none repeat scroll 0 0 #29C5E6; color: #fff; font: 300 30px @brand-font; padding: 0 10px; text-transform: uppercase; } } }سيتمّ إضافة div وبالصنف team، والذي يحتوي بطاقات فريق العمل، حيثُ أنّ كل كرت هو عمود وبعرض مساوي إلى أربعة أعمدة من النّظام الشبكي، وجميعها تحتوي على إزاحة بعمود واحد ما عدا الكرت الأول من كل صفّ، وتُطبّق هذه الإزاحة باستخدام الصنف col-sm-offset-1، ويتألّف كل كرت من صورة والوصف الوظيفي لكل عضو من أعضاء الفريق. <div class="team"> <div class="row"> <div class="col col-sm-4"> <img src="images/team/Doe.jpg" alt="John Doe" class="thumbnail"> <div class="caption"> <h3>John Doe</h3> <p>ceo</p> </div> </div> <div class="col col-sm-4 col-sm-offset-1"> <img src="images/team/Pittsley.jpg" alt="Saundra Pittsley" class="thumbnail"> <div class="caption"> <h3>Saundra Pittsley</h3> <p>team leader</p> </div> </div> ... </div> <div class="row"> <div class="col col-sm-4"> <img src="images/team/Nobriga.jpg" alt="Ericka Nobriga" class="thumbnail"> <div class="caption"> <h3>Ericka Nobriga</h3> <p>art director</p> </div> </div> <div class="col col-sm-4 col-sm-offset-1"> <img src="images/team/Rousselle.jpg" alt="Cody Rousselle" class="thumbnail"> <div class="caption"> <h3>Cody Rousselle</h3> <p>senior ui designer</p> </div> </div> ... </div> </div>سيتمّ إضافة التنسيق التّالي إلى ملفّ التنسيق بهدف مُلائمة المُحتوى السابق مع التصميم: body { ... .wrapper { ... .team { .row { margin-top: 20px; .col { white-space: nowrap; .thumbnail { margin-bottom: 5px; } } .col-sm-offset-1 { margin-left: 3.7%; } .caption { h3 { font: 300 16px @brand-font; margin: 0; } p { font: 300 14px @brand-font; color: @brand-primary; margin: 0; } } } } } }تمّ التعديل في الشيفرة السابقة على الصنف col-sm-offset-1، حيثُ أنّ الهامش الخاصّ به واسعٌ نوعًا ما، ولذلك تمّ تحديده بالقيمة 3.7%. تصميم ذيل الصّفحةيتألّف ذيل الصّفحة من أربعة أجزاء رئيسية: تغذية توتير (Twitter feed)خريطة الموقع (site map)روابط الشبكات الاجتماعيّة (social links)الشعار مع نص حقّ النشر (logo with copyright text) سيتمّ في البداية إنشاء الحاوية الرئيسيّة لذيل الصّفحة، والأعمدة الخاصّة بكل جزء: <footer> <div class="container"> <div class="row"> <div class="col-md-8 col-xs-12 twitter"></div> <div class="col-md-4 col-xs-12 sitemap"></div> <div class="clearfix visible-sm visible-xs"></div> <div class="col-md-6 col-xs-12 social"></div> <div class="col-md-6 col-xs-12 footer-logo"></div> </div> </div> </footer>سيتمّ تنسيق ذيل الصّفحة على الشكل التّالي: footer { background: #7e7e7e; color: #dbdbdb; font-size: 11px; overflow: hidden; .container { height: 110px; padding: 10px 0; } }يَظهر وسم ذيل الصّفحة (footer) على كامل عرض الشاشة، بينما تظهر الحاوية الداخليّة بالمُنتصف، ولاصطفاف العناصر داخل ذيل الصّفحة تم استخدام نظام الأعمدة. تغدية توتير (Twitter feed) صياغة تغذية توتير هي على الشكل التّالي: <div class="col-md-8 col-xs-12 twitter"> <h3>Twitter feed</h3> <time datetime="2015-03-03"><a href="#">03 mar</a></time> <p>In ultricies pellentesque massa a porta. Aliquam ipsum enim, hendrerit ut porta nec, ullamcorper et nulla. In eget mi dui, sit amet scelerisque nunc. Aenean aug</p> </div>والتنسيق هو على الشكل التّالي: body { ... footer { ... .container { ... h3 { border-bottom: 1px solid #919191; color: #ffffff; font-size: 14px; line-height: 21px; font-family: @brand-font; margin: 0 0 10px; text-transform: uppercase; } p { margin: 5px 0; } .twitter { p { padding-right: 15px; } time a { color: #b4aeae; text-decoration: underline; } } } } }تمّ تخصيص تنسيق جميع العناوين بذيل الصّفحة وذلك للخط والهوامش، واستخدام الحروف الكبيرة، وذلك باستخدام الخاصّيّة text-transform، ومن أجل الرابط الّذي يعرض التاريخ، تمّ ضبط اللّون والخطّ السفلي (underlining). خريطة الموقع (Sitemap)تتألّف خريطة الموقع من عمودين متساويين محتويان على روابط: <div class="col-md-4 col-xs-12 sitemap"> <h3>Sitemap</h3> <div class="row"> <div class="col-md-12"> <a href="/home/">Home</a> <a href="/about/">About</a> <a href="/services/">Services</a> </div> <div class="col-md-12"> <a href="/partners/">Partners</a> <a href="/customers/">Support</a> <a href="/contact/">Contact</a> </div> </div> </div>سيتمّ تطبيق التنسيق التّالي، والذي يَخصّ اللّون والخطّ والهامش الخاصّ بالروابط: body { ... footer { ... .container { ... a { color: #dbdbdb; } .sitemap a { display: block; font-size: 12px; margin-bottom: 5px; } } } }الأيقونات الاجتماعيّة سيتمّ وضع جميع الروابط (الأزرار) داخل قسم وبالصنف social: <div class="col-md-4 col-xs-12 social"> <h3>Social networks</h3> <a href="http://twitter.com/" class="social-icon twitter"></a> <a href="http://facebook.com/" class="social-icon facebook"></a> <a href="http://plus.google.com/" class="social-icon google-plus"></a> <a href="http://vimeo.com/" class="social-icon-small vimeo"></a> <a href="http://youtube.com/" class="social-icon-small youtube"></a> <a href="http://flickr.com/" class="social-icon-small flickr"></a> <a href="http://instagram.com/" class="social-icon-small instagram"></a> <a href="/rss/" class="social-icon-small rss"></a> </div>وللتنسيق الروابط ضمن ذيل الصّفحة سيتمّ تطبيق التّالي: body { ... footer { ... .container { ... .social { .social-icon { width: 30px; height: 30px; background: url(../images/social.png) no-repeat; display: inline-block; margin-right: 10px; } .social-icon-small { width: 16px; height: 16px; background: url(../images/social-small.png) no-repeat; display: inline-block; margin: 5px 6px 0 0; } .twitter { background-position: 0 0; } .facebook { background-position: -30px 0; } .google-plus { background-position: -60px 0; } .vimeo { background-position: 0 0; } .youtube { background-position: -16px 0; } .flickr { background-position: -32px 0; } .instagram { background-position: -48px 0; } .rss { background-position: -64px 0; } } } } }تمّ في الشيفرة السابقة استخدام أسلوب ما يُعرف بالاسم sprites، وهو أسلوب شائع يُستخدم في تسريع تحميل الصّفحة وذلك عن طريق جمع مجموعة من الصور في صورة واحدة، وعليه فالمتصفّح سيطلب صورة واحدة بدلًا من عدّة صور، أي طلبًا واحدًا بدلًا من طلبات عدّة، في المشروع الحالي تمّ تقسيم الأيقونات الاجتماعيّة إلى صورتين الأولى بالاسم social.png والثانية بالاسم social-small.png، واستخدام كلْ منها كخلفيّة باستخدام الخاصّيّة background وتحديد موضع كل خلفيّة باستخدام الخاصّيّة background-position، على أنّ يتمّ التبديل بين كل رابط وما يخصّه من شعار. نص حقّ النشرسيتمّ استخدام صورة ذات رابط للشعار، وفقرة (paragraph) أسفله مع نصّ حق النشر. ستكون الصياغة على الشكل التّالي: <div class="col-md-8 col-xs-12 footer-logo"> <a href="/"><img src="images/footer-logo.png" alt="Whitesquare logo"></a> <p>Copyright © 2015 Whitesquare.</p> </div>سيتمّ تنسيق هذا القسم بشكل مُشابه للقسم السابق، مع اختلاف وحيد، وهو الإزاحة إلى جهة اليمين: body { ... .footer { ... .container { ... .footer-logo { float: right; margin-top: 20px; font-size: 10px; text-align: right; a { text-decoration: underline; } } } } }الختاميكون إلى هنا قد تمّ الانتهاء من تصميم كامل الصّفحة، يُمكن الوصول إلى الملفّات المصدريّة الخاصّة بالمشروع بتحميلها أو استعراض تصميم المشروع من هنا. ترجمة – وبتصرّف – للمقال Page layout with Bootstrap 3 part 2.
-
سيكون هذا الدرس مُتابعة لدروس Boostrap الّتي قدّمتها الأكاديميّة، وفيه سيتمّ تجهيز وتخطيط صفحة عامّة تصلح لمُختلف الأغراض والاحتياجات. يعود استخدام أُطر العمل (frameworks) بالنفع الكبير على المُطوّر، حيثُ لم يَعد على المُطوّر التفكير بالمشاكل المُتكرّرة ورُبما التافهة، وهي مشاكل قد تمّ حلها بالفعل من قبل صانعي أُطر العمل، فعلى السبيل المثال، التوافقيّة بين المُتصفّحات، دعم أبعاد أو أحجام الشاشة المُختلفة (التجاوبية)، إلى آخره من المشاكل الأخرى، ويُسرّع هذا الأسلوب أو هذا النمط من التطوير كثيرًا من عمليّة تخطيط وتطوير الموقع. يتميّز إطار العمل Bootstrap بشهرته الواسعة الّتي يتمتّع بها، الأمر الّذي يجعل من صيانة وتنقيح شيفرة أي مُطوّر سهلةً في التعديل من قِبل أي مطوّرٍ آخر، مع عدم إغفال الدعم والتوثيق القويّ الّذي يملكه على الإنترنت. تبرز مساوئ استخدام أُطر العمل في حقيقة أنّ على الصّفحة تحمّل أعباء مُجمل شيفرة الإطار (مُجمل التنسيقات الزائدة)، وحتّى عند استخدام جزء صغير من الإطار، على الجهة الأُخرى، فإن أُطر العمل هي أداةٌ فعّالة في بناء نماذج أوليّة للمشاريع (prototyping)، أو في إنشاء صفحات يكون فيها جماليّة التصميم أمرًا ثانويًّا، كما هو الأمر مع صفحات إدارة الموقع (administration pages)، ولكن عند الرغبة في إنشاء تصميم مُحدّد وذو مواصفات مُعيّنة، فإن استخدام هذه الأُطر قد يُصعب من عمليّة التصميم أكثر مما هو عليه الأمر من بناء التصميم من نقطة الصفر، ومع ذلك فهو أمرٌ مُمكن وليس مُستحيلًا. سيكون المشروع النهائيّ على الشكل التّالي: ملاحظة حول استخدام Bootstrap يوجد طرقٌ عدّة للتعامل مع تنسيقات إطار العمل Bootstrap، سواءً بدون استخدام LESS أو باستخدام LESS. استخدام Bootstrap بدون LESS يُستحسن للمُبتدئين في التعامل مع Bootstrap تنزيل نسخة Bootstrap المُترجمة/المُجمّعة (compiled) وإرفاقها في المشروع، ومن ثمّ القيام بإنشاء ملفّ CSS فارغ وربطه مع المشروع بعد ملفّ bootstrap.css: <link href="css/bootstrap.min.css" rel="stylesheet"> <link href="css/styles.css" rel="stylesheet"> ولكي يتمّ التغيير من تنسيقات bootstrap الافتراضيّة، فيجب الكتابة في الملفّ style.css: a { color: #00ff00 } block { background-color: #dddddd } إن مساوئ استخدام الأسلوب السابق كما هو واضح هو أنّ على المُطوّر البحث يدويًّا عن التنسيق الصحيح عند التغيير، ولن يكون الأمر سهلًا في مُعظم الأحيان، باعتبار أنّ بعض المُعامِلات (parameters) تُطبّق على العديد من المُحدّدات (selectors) عند التعديل، مع العلم أن أداة التخصيص الخاصّة بالإطار قد تساعد المُطوّر بعض الشيء، حيثُ أنها تستطيع ترجمة جميع تغييرات المُطوّر، ولمرّة واحدة، ولكن عند رغبة المُطوّر في تغيير مُعامل جديد، فعليه إعادة تحديث جميع قيم الحقول لكي يُعاد ترجمتها مرّةً أُخرى. استخدام Bootstrap مع LESS تعمل هذه الطريقة بجعل جميع متغيّرات Bootstrap مخزّنة في ملفّات ذات اللاحقة .less، وعلى المُطوّر العمل مع هذه المتغيّرات وترجمتها إلى ملفّات ذات اللاحقة .css (يدويًّا أو آليًّا) وكما تقتضي الضرورة. مع العلم أنّ في ملفّ HTML كل ما يجب عمله هو ربط ملفّات CSS المُترجمة، ولذلك فإن هذه الطريقة هي الطريقة الأفضل والأكثر مرونةً. يوجد العديد من الطرق في تجميع أو ترجمة ملفّات LESS، وحرية الاختيار للمطوّر، مع العلم أنّ Bootstrap نفسه يستخدم Grunt في تجميع ملفّات less، ومن الخيارات المُتاحة هو WinLess لمُستخدمي ويندوز، أو SimpLESS لمُستخدمي أنظمة Mac، أو Koala لمُستخدمي لينكس، وتعمل جميع هذه الأدوات الأمر نفسه، وذلك عبر الوصول إلى ملفّات LESS والانتظار لحدوث أي تغيير فيها، وعندما يقوم المُطوّر بإجراء هذا التغيير، ستقوم الأداة بتجميع وإنشاء ملفّ CSS الموافق، ولذلك ليس على المُطوّر إجراء التجميع أو الترجمة يدويًّا بعد كل تغيير، فبكل بساطة يتم إجراء التغييرات ومن ثم الحفظ، لتظهر النتائج بشكل مُباشر على الموقع وهي بالفعل مُترجمة (compiled) ومضغوطة (compressed). إنشاء المشروع باستخدام Bootstrap سيتمّ في البداية إنشاء بُنيان وهيكليّة ملفّات المشروع وذلك عبر: إنشاء مُجلّد باسم المشروع وليكن whitesquare-bootstrap. إنشاء مجلدان فرعيان: الأول src للملفّات المصدريّة، والثّاني www لملفّات الموقع النهائيّة. إنشاء مجلد فارغ بالاسم images وملفّ فارغ بالاسم index.html داخل المُجلّد www. تنزيل Bootstrap ونسخ مُحتويات الملفّ المضغوط إلى مُجلّد www. تنزيل الملفّات المصدريّة الخاصّة بـ Bootstrap ونَسخ منها المُجلّد less، ووضعه في المُجلّد src الخاصّ بالمشروع. إنشاء ملفان بجانب المُجلّد less/bootstrap، يحمل الأوّل الاسم styles.less ويحمل الثّاني الاسم variables.less، ليتم استخدامهم في تعديل خصائص Bootstrap الأساسيّة، وهذا يُقدّم سرعة في التحديث والتعديل على التنسيق. سيتمّ في الخطوة التّالية إعداد عمليّة ترجمة ملفّات LESS إلى CSS. سيتمّ العمل على الأداة WinLess، وهي سهلة الاستخدام، فكل ما يجب عمله هو اختيار ‘Add folder’ منها، ومن ثُمّ تحديد مسار المُجلّد الّذي يحتوي ملفّات LESS: C:\whitesquare-bootstrap\src\less يحتوي المُجلد السابق على قائمة بجميع الملفّات، سيتمّ اختيار الملفين الأخيرين: styles.less و variables.less، ومن ثُمّ الضغط بالزر الأيمن واختيار من القائمة المُنسدلة الاختيار ‘Select output file’، ومن ثُم تحديد مسار ملفّات CSS. ..\..\www\css\styles.css ..\..\www\css\variables.css بعد ذلك، وعند إجراء أي تعديل على ملفّات LESS، سيتمّ إعادة الترجمة من جديد للحصول على ملفّات CSS مُترجمة وبالتعديلات الجديدة. ملاحظات أصبحت تركيبة وبنية المشروع جاهزة بعد إنشاء الملفّات السابقة، ولكن على المُطوّر الأخذ بعين الاعتبار الأمور التّالية قبل الشروع في التصميم: كيف ستقدّم الصّور، كيف سيتمّ توزيعها وتقسيمها في أرجاء الصّفحة. كيف سيتمّ استخدام المُكوّنات (components). ما هي التنسيقات الأساسيّة. ما هو المُخطّط النهائي. بعد الإجابة على الأسئلة السابقة من المُمكن المُتابعة مع التصميم. إعداد صور الموقع سيتمّ في هذه المرحلة تجهيز الصور والّتي ستستخدم في جميع الصفحات وليس لها علاقة بالمُحتوى، وستكون هذه الصور في المشروع الحالي على الشكل التّالي: الصورة الّتي تعرض عنوان الموقع (خريطة): images/map.png صور شعار الموقع: images/logo.png images/footer-logo.png صور الخلفيّة: /images/bg.png /images/h1-bg.png صور الأيقونات الاجتماعية، وهي مُقسّمة على صورتين ليتم استخدام أسلوب sprite معهم بهدف تحميل الصّفحة بشكل أسرع: /images/social.png /images/social-small.png المُكوّنات (Components) يَكمن الاختلاف بين تصميم الموقع باستخدام Bootstrap وبين التصميم باستخدام الأدوات الأصليّة (native) في أنّ Bootstrap يُقدّم مفهوم المُكوّنات (components)، وتُمثل هذه المُكوّنات أجزاءً شائعة من HTML مُعدّة بشكل مُسبق مع تنسيقها، وتَستخدم في بعض الأحيان هذه المُكوّنات جافا سكريبت، ومن المُمكن استخدام مكوّنات Bootstrap كما هي، أو يُمكن إعادة تنسيق هذه المُكوّنات، فكل ما يحتاجه الأمر هو تغيير قيم المُتغيّرات في Bootstrap لذلك، ولكن عند الرغبة في المزيد من المرونة في التغيير، فيُمكن للمُطوّر دائمًا تغيير وتعديل HTML و CSS كما يَحلو له، وفي العودة إلى المشروع، يُمكن مُلاحظة أنّه سيتمّ الحاجة إلى المُكوّنات التّالية: من أجل تصميم الأعمدة (columns) وتوزيعها، سيتمّ استخدام النّظام الشبكي (row, col). من أجل إجراء حقل البحث، والذي هو نموذج (form) من النوع "ضمن السطر" (inline) سيتمّ استخدام (form-inline - input-group - btn) من أجل التنقّل (navigation)، سيتمّ استخدام الوسم <nav> مع الصنف (navbar). من أجل القوائم الفرعيّة، سيتمّ استخدام قائمة مُجمّعة (group list) وباستخدام الصنف list-group. من أجل لوحة الظهور (panel) سيتمّ استخدام النصف panel. من أجل لوحة ظهور كبيرة سيتمّ استخدام الصنف jumbotron. من أجل إطارات الصور، سيتمّ استخدام thumbnail. تظهر جميع المُكونات السابقة في توثيق المكوّنات الخاصّ بـ Bootstrap. تنسيق أساسي يَملك Bootstrap بالفعل مُعظم التنسيقات المطلوبة للمشروع، ولكن سيتمّ الحاجة فقط إلى التعديل عليهم عند الحاجة، ويُمكن عمل ذلك بالتعديل على الملفّ src/less/variables.css. سيتمّ أوّلًا إضافة بعض المُتغيّرات والّتي لم يتمّ إعدادها افتراضيّا في Bootstrap، ولكي يتمّ استخدامها فيما بعد: يَضبط المُتغيّر التّالي الخط المُستخدم في المشروع: @brand-font: 'Oswald',sans-serif; كما سيتمّ التعديل على خيارات Bootstrap للتوافق مع رؤية المشروع، والّتي ستكون في مُعظمها تخصّ الألوان: /* gray background of the page */ @body-bg: #f8f8f8; /* blue background */ @ brand-primary: #29c5e6; /* background of panels */ @panel-bg: #f3f3f3; /* frame color of panels */ @panel-inner-border: #e7e7e7; /* remove rounding in blocks */ @border-radius-base: 0; /* primary buttons have blue background */ @btn-primary-bg: @brand-primary; /* if the screen width is more then 992px, then the container width is 960px */ @container-md: 960px; /* if the screen width is more 1200px, then the container width is 960px again */ @container-lg: @container-md; /* main font is Tahoma */ @font-family-base: Tahoma, sans-serif; /* base font size */ @font-size-base: 12px; /* main color of text */ @text-color: #8f8f8f; /* gray background of text fields */ @input-bg: @panel-bg; /* gray frame of text fields */ @input-border: @panel-inner-border; /* gray color of the text in the fields */ @input-color: #b2b2b2; سيتمّ البدء في كتابة التنسيقات الخاصّة بالمشروع، بعد أنّ تمّ الانتهاء من المُتغيّرات، وذلك في الملفّ styles.less، لكن يجب أوّلًا استيراد ملفّ Bootstrap العامّ وملفّ المُتغيّرات: @import "bootstrap/bootstrap.less"; @import "variables.less"; يَجدر الذكر هنا، أنّ ليس جميع التنسيقات (التي تكون مُعدّة من قبل الإطار نفسه) من المُمكن تغييرها باستخدام المُتغيّرات، بل يجب تغييرها يدويًّا: p { margin: 20px 0; } .form-control { box-shadow: none; } .btn { font-family: @brand-font; } body { border-top: 5px solid #7e7e7e; background-image: url(../images/bg.png); } ستقوم السطور السابقة بإزالة ظل عناصر النموذج (form elements)، وتحديد خطّ خاصّ للنصّ داخل الزر، وإضافة صورة خلفيّة لكامل الصّفحة وحدّ (border) علوي لها. لن يتمّ بعد الآن ذكر مكان وضع التنسيقات، فستكون دائمًا على الشكل التّالي: المُتغيرات في الملفّ variables.less، وجميع التنسيقات المُخصّصة ستكون في الملفّ styles.less. هيكل HTML يبدأ مُخطط الموقع عادةً بما يُسمى هيكل HTML أو HTML skeleton، وهو على الشكل التّالي: <!DOCTYPE html> <html> <head> <title>Bootstrap 3 page layout</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link href="css/styles.css" rel="stylesheet"> <!--[if lt IE 9]> <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script> <script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script> <![endif]--> </head> <body> </body> </html> تمّ في السطور السابقة العمل على بُنيان مُستند HTML5 الرئيسي، حيثُ تمّ في الوسم title الإشارة إلى عنوان الصّفحة، وهو ‘Bootstrap 3 page layout’، وفي الوسم <meta> تحديد عرض الصّفحة على أجهزة الهاتف المحمول ليكون مساويًا إلى عرض الشاشة، وضبط مُستوى التكبير (zoom level) في التحميل الأوّل للصفحة، ومن ثُم تمّ ربط صفحة التنسيق (stylesheet)، ومن أجل المُتصفّح Internet Explorer (قبل الإصدار التاسع) تم كتابة سكريبت يَسمح بعرض مُخطّط الصّفحة بشكل مُلائم. مُخطّط الصّفحة يتألّف مُخطّط الصّفحة من جزئيين: الحاوية الرئيسيّة للمُحتوى الرئيسي، والّتي تتمركز الشاشة وذيل الصّفحة (footer)، وتتألّف الحاوية الرئيسيّة من عمودين: المُحتوى الرئيسي، والشريط الجانبي (sidebar)، ويأتي من الجهة العلويّة رأس الصّفحة (header)، وشريط التنقل (nav)، وعنوان الصّفحة (heading). سيتمّ إضافة الشيفرة (الكود) التّالية إلى جذع الصّفحة (body): <body> <div class="wrapper container"> <header></header> <nav></nav> <div class="heading"></div> <div class="row"> <aside class="col-md-7"></aside> <section class="col-md-17"></section> </div> </div> <footer></footer> </body> تقدّم الشيفرة السابقة التقسيم العام الخاصّ بالأعمدة (columns)، وهي مُحتوات داخل الصنف (class) المُسمى صفّ (row)، وتبدأ أصناف الأعمدة بالبادئة col-، ومن ثم حجم الشاشة وهو أحد أربع (xs, sm, md, lg)، ومن ثم تنتهي بقيمة عرض العمود. يُمكن للأعمدة أنّ تُحدّد معًا وبقيم أصناف مُختلفة للشاشات، وتُعبّر هذه الأصناف عن عرض العمود لقياسات الشاشة المُختلفة، فمثلًا: class="col-xs-12 col-md-8" سيتمّ تطبيق الصنف col-xs-12 مع الشاشات كبيرة الحجم، وتطبيق الصنف col-md-8 على الشاشات الصغيرة، وتُطبّق هذه الأصناف على عرض الشاشات الأكبر والمساوي لقيمة الصنف المُحدّد، وعليه فإن تطبيق الصنف col-md-* على العنصر، سوف لن يؤثر على أجهزة الشاشات المُتوسطة فقط بل أيضًا على أجهزة الشاشات الكبيرة، وذلك في حال عدم حضور صنف من أصناف الشاشات الكبيرة (col-lg-*). تمّ في الشيفرة السابقة استخدام الأصناف col-md-7 و col-md-17 والّتي تُشير إلى أنّ كتلة <aside> ستستحوذ على عرض عمود ذو قياس 7 في الشاشات المُتوسطة، وستستحوذ الكتلة <section> على عرض عمود ذو قياس 17، وذلك نسبةً إلى الحاوية الأب (parent container)، مع العلم أنّ مجموع سعات الأعمدة في Bootstrap هو 12، ولكن تمّ زيادة العدد (إلى الضعف) وذلك بهدف الحصول على مزيد من المرونة في التوزيع، ولكن بشكل عام استخدام 12 عمود هو مناسب لمعظم التصاميم. سيتمّ في الشيفرة التّالية إضافة بعض الحشوة لمُلائمة التنسيق، وذلك إلى الصنف .wrapper، ورأس الصّفحة: body { ... .wrapper { padding: 0 0 50px 0; } header { padding: 20px 0; } } تمّ في الشيفرة السابقة الاستفادة من المعالج المُسبق (preprocessor) وذلك في صياغة التنسيق، حيثُ يَسمح لنا ذلك بكتابة تنسيقات مُتداخلة (nested) وبدون تكرار، والذي سيتمّ صياغتها بعد الترجمة إلى: body .wrapper {...} body header {...} يَسمح هذا الأسلوب من الإعداد في رؤية بُنيان HTML الصحيح داخل CSS، ويُقدّم نوعًا من الفرز والتنظيم في كتابة شيفرة CSS. الختام تمّ في هذا الجزء التعرّف على Bootstrap، وإعداد بيئة العمل، وكيفية بناء بُنيان ملفّات المشروع، في الجزء الثّاني سيتمّ الدخول في تصميم كل جزء من أجزاء الصّفحة. ترجمة – وبتصرّف – للمقال Page layout with Bootstrap 3.