مرحبًا. اليوم سننظر في كيفية تمديد الخلفية باستخدام أدوات CSS (دون تدخل أدوات أخرى، مثل جافا سكريبت وغيرها مثلها).
تمتد خلفية CSSأصبحت هذه الوسائل ممكنة مع ظهور CSS3، وتحديدًا بمساعدة خاصية حجم الخلفية. يجب أن أقول أن هذه الخاصية تعمل بشكل أفضل بكثير من الحلول المماثلة في Javascript (التي تم استخدامها قبل ظهور حجم الخلفية)، لأنها تتفاعل بشكل أسرع وأكثر ملاءمة مع التغييرات في حجم المتصفح، وتنعيم الصورة الممتدة بشكل أسرع، كما لقد أحبوا أن يقولوا في أوائل العقد الأول من القرن الحادي والعشرين، x، - "سيعمل حتى مع تعطيل Javascript."
يمكن أن تحتوي خاصية حجم الخلفية على قيم متعددة.
1) يمكن أن يكون هذا أحد التوجيهات: تغطية أو احتواء.
حجم الخلفية: تحتوي على؛ /* يقوم بقياس الصورة مع الحفاظ على التناسب بحيث يتم احتواء الصورة بأكملها داخل الكتلة. */ حجم الخلفية: الغلاف؛ /* يقوم بقياس الصورة مع الحفاظ على نسبة العرض إلى الارتفاع بحيث يكون عرضها أو ارتفاعها مساويًا لعرض أو ارتفاع الكتلة. */
2) يمكن أن تكون نسبة (100% أو 94% من عرض الحاوية). في هذه الحالة، يمكنك استخدام إما قيمة نسبة مئوية واحدة أو 2. إذا كانت هناك قيمتان، فسيتم قياس ارتفاع الصورة وعرضها في نفس الوقت، ويتم ضبط كل قيمة بما يتناسب مع النسب المئوية المحددة في حدود).
حجم الخلفية: 100%؛ /*يعادل توجيه الغلاف*/ حجم الخلفية: 100% 50%; /*العرض سيكون 100% من عرض الكتلة، ولكن الارتفاع سيكون 50% فقط، ومن المرجح أن تكون الصورة مشوهة*/
3) القيمة العددية المباشرة (بالبيسكل، السنتيمتر، em، إلخ). يمكن أن يكون هناك أيضًا معلمتان (أو 1)، كما في الحالة السابقة.
4) قيمة السيارات. يشير إلى أنه لن يتم تمديد الصورة، ولكن سيتم استخدام الحجم الأصلي. في هذه الحالة، يمكن أن يكون هناك أيضًا معلمتان أو معلمة واحدة، أي أنه يمكنك تحديد ما يلي:
حجم الخلفية: 60% تلقائي؛ /*عرض الصورة سيكون 60%، وارتفاعها يتناسب مع حجم الصورة الأصلية*/
إذا حكمنا من خلال موقع "هل يمكنني استخدام"، فإنه سيعمل في كل شيء المتصفحات الحديثة، بما في ذلك إصدارات IE لا تقل عن 9. لذلك، من حيث المبدأ، لا يوجد سبب للقلق. انظر جدول التوافق:
وجدت هذا الدرس على واحد قناة يوتيوب. ميزة مفيدة جدًا لمصمم الويب في رأيي.
في بعض الأحيان، لا يكون عرض الصورة الأصلية كافيًا لأي فكرة تصميمية، كما يؤدي تمديدها عبر العرض إلى تشويه الكائنات المطلوبة. للحفاظ على هذه الكائنات سليمة مع الاستمرار في تمديد خلفية الصورة، يوفر لنا PhotoShop أدوات معينة. وهكذا، في النهاية لدينا من الصورة الأصلية:
يجب أن يبدو مثل هذا:
دعونا نبدأ. افتح صورتنا في PhotoShop وحدد الكائن الذي نحتاجه:
بعد ذلك، انتقل إلى علامة التبويب التحديد >> حفظ التحديد
وقم بتعيين اسم عشوائي لهذا التحديد:
وبالتالي، أنشأنا منطقة سيتم حمايتها لاحقا من التغييرات. والخطوة التالية هي الذهاب إلى تحرير >> مقياس إدراك المحتوى:
وتأكد من الإشارة إلى الكائن المحمي:
الجميع. كل ما تبقى هو تغيير عرض الصورة باستخدام الأدوات القياسية (أو اللوحة العلويةعن طريق تغيير نسبة العرض، أو ببساطة سحب الصورة). مهمقبل ذلك (أو في المرحلة الأولية)، قم بتغيير حجم اللوحة القماشية بحيث لا تتجاوز حدود الصورة منطقة رؤيتها.
تحيات. في هذه المقالة، أريد مشاركة ثلاث طرق لوضع صورة كخلفية لصفحة بأكملها باستخدام HTML + CSS فقط (بدون JS).
لذلك، متطلباتنا لصورة الخلفية هي كما يلي:
في رأيي هذا أفضل طريقةلأنه الأبسط والأكثر إيجازًا وحداثة. ويستخدم خاصية حجم الخلفية CSS3، والتي نطبق عليها علامة HTML. إنه HTML، وليس الجسم، لأنه ارتفاعه أكبر من أو يساوي ارتفاع نافذة المتصفح.
اضبط الخلفية لتكون ثابتة ومركزة، ثم اضبط حجمها باستخدام حجم الخلفية: الغلاف .
HTML (صورة الخلفية: url(images/background.jpg); تكرار الخلفية: عدم التكرار; موضع الخلفية: المركز المركزي; مرفق الخلفية: ثابت; -حجم خلفية webkit: الغلاف; -moz-background- الحجم: الغلاف - حجم الخلفية: حجم الخلفية: الغلاف ؛
تعمل هذه الطريقة في
Chrome (أي إصدار) Opera 10+ Firefox 3.6+ Safari 3+ IE 9+
لضمان تحميل الصور بسرعة، قم باستضافة مواقعك فقط مع موفري الاستضافة الموثوقين، مثل المستخدمين و محركات البحثأحب المواقع السريعة.
إذا كان عرض النافذة أصغر من عرض الصورة، فسيتم استخدام استعلام الوسائط لتوسيط الخلفية.
img.background ( الحد الأدنى للارتفاع: 100%؛ الحد الأدنى للعرض: 640 بكسل؛ العرض: 100%؛ الارتفاع: تلقائي؛ الموضع: ثابت؛ الأعلى: 0؛ اليسار: 0؛ /* يعتمد على حجم الصورة */ @media screen و (الحد الأقصى للعرض: 640 بكسل)( img.bg ( اليسار: 50%; الهامش الأيسر: -320 بكسل; ) ) )
تعمل هذه الطريقة في:
هناك طريقة أخرى وهي كما يلي: إصلاح الصورة إلى الزاوية اليسرى العليا من الصفحة وتمديدها باستخدام خصائص الحد الأدنى للعرض والحد الأدنى للارتفاع بنسبة 100%، مع الحفاظ على نسبة العرض إلى الارتفاع.
صحيح، مع هذا النهج، لا يتم توسيط الصورة. ولكن يتم حل هذه المشكلة عن طريق التفاف الصورة
، والتي نصنعها ضعف حجم النافذة. ونمد الصورة نفسها ونضعها في المنتصف.
تعمل هذه الطريقة في متصفحات جيدةو آي إي 8+.
آمل أن تكون هذه المعلومات مفيدة لك. شخصيا، كثيرا ما أستخدم هذه الأساليب، وخاصة الطريقة الأولى. ربما توجد طرق أخرى لوضع صورة في الخلفية باستخدام CSS. إذا كنت تعرف عنهم، يرجى مشاركتها في التعليقات.
قم بتمديد صورة الخلفية إلى العرض الكامل لنافذة المتصفح باستخدام CSS3.
لتغيير حجم الخلفية، استخدم خاصية حجم الخلفية واضبط قيمتها على 100%، ثم ستشغل الخلفية عرض نافذة المتصفح بالكامل. بالنسبة للإصدارات الأقدم من المتصفحات، يجب عليك استخدام خصائص محددة مع البادئات، كما هو موضح في المثال 1.
مثال 1: خلفية قابلة للتمدد
HTML5 CSS 2.1 IE Cr Op Sa Fx
نتيجة هذا المثاليظهر في الشكل. 1.
أرز. 1. عرض الخلفية بحجم نافذة مصغر
مع زيادة حجم نافذة المتصفح، ستبدأ الخلفية أيضًا في التوسع، مما سيؤدي إلى تدهور مظهر الصورة (الشكل 2).
أرز. 2. عرض الخلفية بحجم نافذة موسع
الغرض من هذا الدرس هو النظر في طرق التنظيم صورة الخلفيةلموقع ويب يمتد دائمًا على نافذة المتصفح بأكملها.
باستخدام عنصر مضمنة والتي يمكن تغيير حجمها في أي متصفح. قمنا بتعيين خاصية min-height لملء نافذة المتصفح عموديًا، وقمنا بتعيين خاصية العرض على 100% لملئها أفقيًا. قمنا أيضًا بتعيين خاصية min-width لتساوي عرض الصورة بحيث لا تصبح أصغر أبدًا.
الحيلة هي استخدام استعلام الوسائط للتحقق من أن عرض نافذة المتصفح أصغر من عرض الصورة، واستخدام مجموعة من قيمة النسبة المئوية للخاصية اليسرى وقيمة سالبة للهامش الأيسر لتوسيط الخلفية صورة.
إليك كود CSS:
Img.bg ( /* تعيين قواعد ملء الخلفية */ min-height: 100%; min-width: 1024px; /* تعيين معامل التناسب */ width: 100%; height: auto; /* تعيين الموضع */ الموضع: أعلى ثابت: 0؛ اليسار: 0؛) شاشة الوسائط و(الحد الأقصى للعرض: 1024 بكسل) ( /* محدد لكل صورة محددة */ img.bg ( اليسار: 50%؛ الهامش الأيسر: - 512بكسل; / * 50% */ ) )
يعمل في:
أي إصدار من المتصفح العادي: Safari / Chrome / Opera / Firefox.
IE 6: لا يعمل - ولكن يمكنك استخدام بعض حيل تحديد المواقع.
IE 7/8: يعمل معظم الوقت، ولا يقوم بتوسيط الصور الصغيرة، ولكنه يملأ الشاشة بشكل صحيح.
إي 9: يعمل.
هناك طريقة أخرى لحل المشكلة وهي وضع عنصر مضمّن في الصفحة، ثبّت موضعه في الزاوية اليسرى العليا واضبط خصائص الحد الأدنى للعرض والحد الأدنى للارتفاع على 100%، مع الحفاظ على عامل التناسب.
#bg ( الموضع:ثابت; أعلى:0; يسار:0; /* الحفاظ على نسبة العرض إلى الارتفاع */ min-width:100%; min-height:100%; )
ومع ذلك، هذا لا توسيط الصورة. لذلك دعونا نلف الصورة في عنصر
#bg ( الموضع: ثابت؛ أعلى: -50%؛ يسار: -50%؛ عرض: 200%؛ ارتفاع: 200%؛ ) #bg img ( موضع: مطلق؛ أعلى: 0؛ يسار: 0؛ يمين: 0؛ أسفل: 0؛ الهامش: تلقائي؛ الحد الأدنى للعرض: 50%؛
يعمل في:
Safari / Chrome / Firefox (لم يتم اختباره على جميع الإصدارات، ولكنه يعمل بشكل جيد في الإصدارات الأحدث).
آي إي 8+.
يرفض Opera (أي إصدار) وIE العمل بهذه الطريقة (وضع الصورة غير صحيح).
الفكرة بسيطة للغاية، إذا كانت نسبة العرض إلى الارتفاع للصورة (عنصر الخط سيتم استخدامه كخلفية) مقارنة بنسبة العرض إلى الارتفاع لنافذة المتصفح. إذا كان أصغر للصورة، فأنت بحاجة إلى تعيين فقطتم ضبط خاصية عرض الصورة على 100%، وسوف تملأ الشاشة بالارتفاع والعرض. وإذا كان أكثر، ثم تعيين فقطتم ضبط خاصية ارتفاع الصورة على 100%.
#bg ( الموضع: ثابت; أعلى: 0; يسار: 0; ) .bgwidth ( العرض: 100%; ) .bgheight ( الارتفاع: 100%; )
$(function() ( var theWindow = $(window), $bg = $("#bg"), AspectRatio = $bg.width() / $bg.height(); وظيفة resizeBg() ( if ((theWindow .width() / theWindow.height())< aspectRatio) { $bg .removeClass() .addClass("bgheight"); } else { $bg .removeClass() .addClass("bgwidth"); } } theWindow.resize(function() { resizeBg(); }).trigger("resize"); });
يعمل في:
IE7+ (مع بذرة، من المحتمل أن تعمل في IE6)
في جميع المتصفحات الأخرى.
كل طريقة حل لها مزاياها وعيوبها. تحتاج فقط إلى اختيار الخيار المناسب لحالة معينة. حسنا، أو تقديم بنفسك.