آموزش تکنولوژی و طراحی سایت

وبلاگی برای مجتمع کردن مباحث جذاب و به روز طراحی سایت و تکنولوژی

آموزش تکنولوژی و طراحی سایت

وبلاگی برای مجتمع کردن مباحث جذاب و به روز طراحی سایت و تکنولوژی

  • ۰
  • ۰

CSS Sprites چیست؟

CSS Sprites چیست؟

CSS sprite یک تکنیک بهینه سازی عملکرد طراحی سایت است که تصاویر چندگانه را به یک تصویر منفرد به نام یک صفحه ی sprite یا مجموعه کاشی ترکیب می کند. Sprites با کاهش تعداد بارگیری های لازم برای رندر یک صفحه وب، تراکم شبکه را کاهش می دهد.

شما با استفاده از تکنیک CSS Sprite  میتوانید سرعت سایت خود را تا حد زیادی افزایش دهید. تا همین چند وقت پیش همه طراحان سایت عکس ها را به تصاویر کوچکتر تقسیم میکردند تا صفحات سریعتر بارگزاری شوند ولی این تکنیک با فریب چشم انسان و نشان دادن تصاویر در هر گوشه از صفحه این حس را میدهد که سرعت بارگزاری افزایش یافته است ولی در واقع هرکدام از این تصاویر یک فراخوان از HTTP را بهمراه دارد و بازدهی صفحه شما را به شدت کاهش میدهد.

 

بررسی اجمالی

تصاویر برای یک وب سایت به طور معمول در فایل های شخصی ذخیره می شود. بعضی از این تصاویر ممکن است مربوط باشد یا ممکن است تغییرات یک تصویر مشابه، مانند یک دکمه ساده و یک دکمه برجسته باشد. هنگامی که کاربر یک صفحه وب را باز می کند، مرورگر خود باید هر یک از این پرونده ها را درخواست کند، و در نتیجه تجربه ای کندتر را تجربه می کند.
با استفاده از CSS sprites، چندین تصویر به یک تصویر واحد به نام یک برگه ی sprite ترکیب می شوند. به جای بارگیری چندین فایل، کاربر یک فایل را دانلود می کند و sprite یا تصویر مورد نیاز را با جابجایی فایل نمایش می دهد. این باعث می شود که هزینه درخواست فایل های چندگانه در هزینه یک فایل بزرگتر را بارگیری کنید.

CSS چگونه کار می کند؟

اجازه بدهید که قبل از توضیح روش CSS Sprite یک نمونه از تاثیر آن را بررسی کنیم. دقت کنید که در CSS زیر هرکدام از عکس ها بصورت جداگانه و با یک دستور فراخوان میشوند.

نحوه کار کد scc sprite

 

با استفاده از CSS Sprite در مثال بالا میتوانیم  بجای 10 تصویر مجزا (2 تصویر برای هر آیکون) یک تصویر بزرگتر داشته باشیم. تصویری به عرض آیکونی که بیشترین عرض را دارد و به ارتفاع مجموع ارتفاع آیکون ها بعلاوه 10 پیکسل (به تعداد عکس ها) میسازیم و آیکون ها را بصورت چپ چین از بالا و به فاصله یک پیکسل بین آنها در تصویر قرار میدهیم.

نحوه انجام کار کد scc sprite

حالا کد CSS جدید را به شکل زیر میسازیم، همانطور که میبینید تنها یک تصویر زمینه قرار دارد و بقیه دستورها با جابجایی این تصویر با استفاده از مختصات X و Y آیکون ها را به نمایش میگذارند.

نحوه انجام کار کد css sprite

با استفاده از CSS Sprite در این مثال ساده تعداد فراخوان HTTP 9 عدد کاهش یافته و حجم تصویر 5/6 کیلوبایت کمتر شد حالا تصور کنید که تا چه حد میتواند در افزایش سرعت سایت موثر باشد.

نحوه کار کد css sprite

چگونگی ایجاد یک CSS Sprite Sheet

ابزارهای زیادی وجود دارد که صفحات Sprite را خودکار سازی می کند، اما برای ایجاد یک برگه ی sprite می توان از هر برنامه ی ویرایش تصویر استفاده کرد..

۱-یک شبکه از پیکسل ها ایجاد کنید:
این شبکه نه تنها به موقعیت تصاویر کمک می کند، بلکه در اشاره به مراجع تصاویر نیز کمک می کند.

۲-تصاویر را اضافه کنید:
تصاویر کوچک ممکن است در یک سلول واحد قرار گیرند، در حالی که تصاویر بزرگتر چندین سلول را می گیرند. بیشتر برگه های Sprite تصاویررا بر اساس اندازه دسته بندی میکند.

۳-CSS را اضافه کنید:
سه خصوصیت برای ایجاد یک فیلد در CSS وجود دارد: عرض، ارتفاع و پس زمینه. عرض و ارتفاع اندازه تصویر را تعیین می کنند، در حالی که پس زمینه ستاره ی اسپریت و موقعیت یاب مورد نظر (در پیکسل ها) را تعیین می کند.

۴-عنصر را به صفحه اضافه کنید:
یک برچسب img با یک تصویر حفره یا سوراخ می تواند CSS sprite را از طریق شناسه یا کلاس طبقه بندی کند. وقتی صفحه بارگذاری می شود، تصویر حفره یا سوراخ جایگزین خواهد شد.

مزایای CSS Sprites

راهنماهای CSS باعث کاهش کل زمان بارگذاری صفحه می شوند، در حالی که شرکت ها کنترل بیشتری برعملکرد وب سایت خود دارند.
کاربران از زمان بارگذاری صفحه سریعتر، از زمانیکه تصاویر به محض بارگیری صفحات ارجاع به نمایش در می آیند، تجربه می کنند.
شرکت ها شاهد عملکرد بیشتر و استفاده کمتر از منابع را به عنوان درخواست های کمتر از HTTP کمتر خواهند بود. در نتیجه این موضوع باعث کاهش میزان تراکم در شبکه می شود.

نتیجه

هنگامی که به دنبال افزایش عملکرد وب هستیم، کاهش تعداد بارگیری ها یک استراتژی است که شرکت ها به آن وابسته هستند. برای خدمات وب با میلیون ها کاربر، یک برگه ی Sprite می تواند تفاوت بین یک میلیون تا ۱۰۰ میلیون بارگیری را مشخص می کند. به ویژه در طراحی سایت فروشگاهی که تعداد کاربران زیادی دارند و درخواست های ارسال می شود این مورد بیشتر اهمیت پیدا می کند.

CSS Spriting یک تکنیک است که برای محدود کردن تعداد درخواست HTTP ایجاد شده توسط یک صفحه وب استفاده می شود. این کار با ترکیب تصاویر چندگانه در یک تصویر و استفاده از ویژگی موقعیت پس زمینه CSS انجام می شود.

 

مثال:
سه پیوند ساده

بیایید تصور کنیم که برخی از پیوندهای شما در صفحه شما وجود دارد:

حذف یک آیتم|تماس با ما|آیا به کمک نیاز دارید؟|

html
|<a href=”#”>Delete an item</a>
|<a href=”#”>Contact us</a>
<a href=”#”>Need help?</a>

سه لینک با استایل

لینک های شما عالی هستند، اما بعضی از تصاویر را کمی کمی ادعا می کنید. شما سه آیکون پیدا میکنید اینجا اند:

html
<img src=”/styles/articles/delete.png”>
<img src=”/styles/articles/group.png”>
<img src=”/styles/articles/help.png”>

با استفاده از CSS و تصاویر، پس زمینه را تنظیم می کنید و کمی از padding را در سمت چپ قرار دهید تا قبل از شروع متن، فضای اضافه کنید. لینک های شما اکنون شبیه این هستند:

حذف یک آیتم|تماس با ما|آیا به کمک نیاز دارید؟|

html

|<a href=”#” class=”nosprite delete”>Delete an item</a>
|<a href=”#” class=”nosprite group”>Contact us</a>
<a href=”#” class=”nosprite help”>Need help?</a>

style type=”text/css”

nosprite { padding-left: 20px; line-height:16px; background-repeat: no-repeat; }.
nosprite.help { background-image: url(‘/styles/articles/help.png’); }.
nosprite.delete { background-image: url(‘/styles/articles/delete.png’); }.
nosprite.group { background-image: url(‘/styles/articles/group.png’); }.

به نظر می رسد عالی است فقط یک مشکل است سه تصویر وجود دارد. برای هر تصویر یک مرورگر وب باید یک اتصال HTTP برای بارگیری تصویر را باز کند. بعضی از مرورگرها فقط می توانند ۲ بار اتصال را در یک بار باز داشته باشند، بنابراین این می تواند صفحه شما را به آرامی کاهش دهد.

سه لینک، با CSS اسپریت

شما می توانید تمام این تصاویر را با استفاده از ژنراتور CSS sprite ترکیب کنید.

html

<img src=”/styles/articles/icon.png”>

ما نمی توانیم تصویر پس زمینه را روی همه آنها به icon.png تنظیم کنیم. این به نظر می رسد:

حذف یک آیتم|تماس با ما|آیا به کمک نیاز دارید؟|

html

|<a href=”#” class=”sprite”>Delete an item</a>
|<a href=”#” class=”sprite”>Contact us</a>
<a href=”#” class=”sprite”>Need help?</a>

این به نظر کاملا درست نیست … مشاهده کنید که تنظیم تصویر پس زمینه به بالا سمت چپ باعث می شود که هر لینک برای نمایش تصویر بالا در ماجرا (در این مورد تصویر حذف شده) باشد. این کار فوق العاده ای است که ما برای انجام آن باید انجام دهیم. ما باید از تعرفه ها برای قرار دادن تصویر پسزمینه درست استفاده کنیم.

html

|<a href=”#” class=”sprite delete”>Delete an item</a>
|<a href=”#” class=”sprite group”>Contact us</a>
|<a href=”#” class=”sprite help”>Need help?</a>

style type=”text/css”

sprite { background: url(‘/styles/articles/icon.png’) no-repeat top left; padding-left: 20px; line-height: 16px; }.
sprite.delete { background-position: 0px 0px; }.
sprite.group { background-position: 0px -26px; }.
sprite.help { background-position: 0px -52px; }.


بیاد داشته باشید که موفقیت های بزرگ با تلاش زیاد بدست میان، انجام مراحل CSS Sprite زمان و دانش زیادی رو طلب میکنه ولی خوشبختانه سرویس رایگانی وجود دارد که ساختن CSS Sprite را برای شما خیلی راحت و سریع انجام میدهد. بهترین نرم افزار در این زمینه SprieMe  است.

البته با پیشرفت بیشتر در زمینه طراحی سایت استفاده از این کد تا حدودی کم رنگ شده است و بیشتر سعی می شود به جای کد زدن آینک ها تبدیل به فونت شوند که این خود سرعت لود سایت را تا میزان زیادی افزایش خواهد داد و نیازی به استفاده از چنین کدهایی وجود نخواهد داشت.

منبع:
https://inten.asia
https://websima.com

 

  • ۹۸/۰۶/۱۲
  • ناهید صفری

css sprite

نظرات (۰)

هیچ نظری هنوز ثبت نشده است

ارسال نظر

ارسال نظر آزاد است، اما اگر قبلا در بیان ثبت نام کرده اید می توانید ابتدا وارد شوید.
شما میتوانید از این تگهای html استفاده کنید:
<b> یا <strong>، <em> یا <i>، <u>، <strike> یا <s>، <sup>، <sub>، <blockquote>، <code>، <pre>، <hr>، <br>، <p>، <a href="" title="">، <span style="">، <div align="">
تجدید کد امنیتی