ویرگول
ورودثبت نام
محمد صالح فدایی
محمد صالح فداییتوسعه دهنده و علاقه مند به مباحث Performance و UX در Front-End
محمد صالح فدایی
محمد صالح فدایی
خواندن ۸ دقیقه·۵ سال پیش

بهبود کارایی در فرانت‌اند: بهینه سازی تصاویر

سلام به همه همراهان گرامی و دوستان عزیز. این هفته هم مطابق برنامه هفتگیمون قراره درباره یکی دیگه از راهکارهای بهبود کارایی در فرانت‌اند صحبت کنیم. اگر تا الان این سری از پست‌ها رو دنبال نکردین، پیشنهاد میکنم از پست اول این مبحث شروع کنین. اگر هم پست قبلی بهبود کارایی در فرانت‌اند رو از دست دادید می‌تونین از طریق پیوند زیر بهش دسترسی پیدا کنین:

https://virgool.io/@ms.fadaei/%D8%A8%D9%87%D8%A8%D9%88%D8%AF-%DA%A9%D8%A7%D8%B1%D8%A7%DB%8C%DB%8C-%D8%AF%D8%B1-%D9%81%D8%B1%D8%A7%D9%86%D8%AA-%D8%A7%D9%86%D8%AF-%D8%A8%D8%AE%D8%B4-2-rsk44ekd1bfb

بهینه سازی تصاویر

تصاویر استفاده شده در رابط کاربری وبسایت، باید بدون تغییر محسوس در محتوا، معنی قابل ارائه به کاربر و کیفیت، بهینه سازی، فشرده و کم حجم شوند. طراح رابط کاربری در هنگام طراحی و توسعه دهنده فرانت‌اند در هنگام کد نویسی رابط کاربری باید به این نکته توجه داشته باشند که تصاویر مورد استفاده باید متناسب با موقعیت و نحوه نمایش بهینه سازی شوند.

چرا؟

تصاویری که بهینه سازی و فشرده شده‌اند سریع‌تر دانلود شده و به دلیل اینکه حجم کمتری دارند، زمان کمتری را جهت پردازش پردازنده (برای نمایش به کاربر) نیاز دارند.

حتما تا به اینجا متوجه شده‌اید که یکی از راه‌های افزایش سرعت در نمایش وبسایت، پایین آوردن حجم منابع مورد استفاده (فایل‌های جاوا اسکریپت، سی اس اس، تصاویر و ...) می‌باشد. این امر از منطق به دور نیست چرا که هر چه حجم هر کدام از منابع کمتر باشد سریع‌تر دانلود می‌شود. وبسایت‌ها مانند اپلیکیشن‌ها نیستند تا کاربر در ابتدای امر منابع مورد استفاده در آن‌ها را دانلود کرده و برای اجرای آن نیاز به اینترنت نداشته باشند. برعکس، وبسایت‌ها بر روی بستر اینترنت قرار دارند و کاربران هم از طریق سیستم عامل‌های مختلف (ویندوز، مک او‌اِس، لینوکس، اندروید و ...)، مرورگرهای مختلف (کروم، سافاری، فایرفاکس و ...)، دستگاه‌های مختلف (که از نظر مشخصات با هم بسیار تفاوت دارند و حتی معماری مشخصی برای پردازنده و ... ندارند) و از سرعت‌هایی پایین تا بالای اینترنت به این وبسایت‌ها دسترسی دارند. به همین دلیل است که حجم فاکتور مهمی برای افزایش سرعت وبسایت است چرا که محتوا سریع‌تر دانلود شده و به در نهایت سریع‌تر به کاربر نمایش داده می‌شوند.

اما حجم کمتر همه چیز نیست. برخی کدهای جاوا اسکریپت خیلی کم حجم هستند اما بخاطر محتوایی که دارند ممکن است مدت زمان زیادی از رشته اصلی پردازنده شما اشغال کنند و عملا وبسایت شما را کند کنند. فرض کنید تصویری دارید که اندازه بسیار بالایی دارد (مثلا 8000 پیکسل در 8000 پیکسل) و به طبع آن حجم بالایی را نیز دارد. اما جدا از مبحث حجم، زمانی که این تصویر برای یک کاربر نهایی برروی وبسایتی به نمایش در بیاید، پردازنده و پردازنده گرافیکی برای رسم این تصویر توان بیشتری را مصرف می‌کنند. حال اگر بازدید کننده شما یک کاربر با یک گوشی میان‌رده اندرویدی باشد احتمالا در زمان نمایش این تصویر، برای لحضاتی با صفحه وبسایت فریز شده مواجه می‌شود که این مورد اصلاً و ابداً خوب نیست.

پس ما به دو دلیل به سراغ بهینه‌سازی و فشرده سازی تصاویر می‌رویم. حجم کمتر و پردازش راحت‌تر.

چگونه؟

برخی از تصاویر قابل جایگزینی با یک نمونه بهتر هستند. به موارد زیر توجه کنید:

  • در برخی مواقع تصاویری استفاده‌ شده‌ است که قابل جایگزینی با افکت‌های سی‌اس‌اس هستند. برای مثال شما از تصاویر به عنوان پس زمینه دکمه‌ها استفاده می‌کنید که می‌توانید آن‌ها را با افکت‌های سی‌اس‌اس جایگزین کنید.
  • در برخی مواقع شما از تصویری استفاده کرده‌اید که در واقع تصویر یک آیکون است. استفاده از آیکون‌ها در فرمت فونت یا svg انتخاب بهتری در مقایسه با استفاده از تصاویر است. به علاوه اینکه فونت‌ها و svgها به راحتی به هر اندازه بزرگ و کوچکی قابل نمایش هستند در صورتی که تصاویر با بزرگتر شدن به صورت پیکسلی و بی‌کیفیت به نمایش در می‌آیند.
  • در برخی مواقع نیز شما می‌توانید تصویر خود را با یک فایل تصویری با فرمت svg جایگزین کنید. تصاویری که قابل جایگزینی با نمونه svg معادل خود هستند، معمولا حجم بیشتر و کیفیت کمتری نسبت به این نوع تصاویر دارند.

اما اگر هر کدام از کارهای بالا برای شما امکان پذیر نبود، دستور عمل زیر را برای بهینه سازی و فشرده‌سازی تصاویر استفاده کنید.

انتخاب مناسب نوع و فرمت تصویر
انواع فرمت‌های متخلف برای تصویر وجود دارد. از فرمت PNG که یک فرمت بدون فشرده سازی است تا فرمت‌های JPEG و GIF و WEPP. اینکه شما از کدام یک از فرمت‌ها استفاده کنید کاملا وابسته به نوع و محتوای تصویر است. مثلا تصاویری که شفاف هستند و پس زمینه ندارند یا تصاویری که از رنگ‌های محدود در آن استفاده شده است از فرمت PNG استفاده می‌شود. در مقابل تصاویری که خروجی دوربین عکاسی هستند و رنگ‌های موجود در تصویر بسیار زیاد هستند از فرمت JPEG استفاده کنید. از GIF هم برای تصاویر متحرک استفاده می‌شود. فرمت WEPP نیز یک فرمت جدید است که هم به صورت فرمت فشرده‌ساز و هم فرمت بدون فشرده‌سازی مورد استفاده قرار می‌گیرد.

استفاده نادرست از هر فرمت می‌تواند بی دلیل حجم تصویر را بالا ببرد. مسئله فقط فشرده سازی نیست. برخی مواقع خروجی PNG که یک فرمت بدون فشرده سازی است حجم کمتری نسبت به خروجی JPEG با فشرده سازی دارد، البته که در اکثر مواقع عکس این موضوع درست است اما در مجموع یک فرمول خاص و مشخصی ندارد بلکه کاملا وابسته به پارامترهای مختلف آن تصویر است. به عنوان نمونه در تصویر زیر مشاهده می‌کنید که خروجی JPEG یک تصویر حدود 80 درصد حجم کمتری نسبت به خروجی PNG همان تصویر دارد.

فرمت PNG با حجم 232 کیلوبایت
فرمت PNG با حجم 232 کیلوبایت
فرمت JPEG با حجم 42 کیلوبایت
فرمت JPEG با حجم 42 کیلوبایت

همانطور که مشاهده می‌کنید فرمت JPEG این تصویر بدون تغییر محسوس در کیفیت، 81 درصد حجم کمتری نسبت به نمونه PNG دارد.

حذف اطلاعات متای تصاویر

داده‌های متا (meta data) در واقع داده‌های مرتبط با تصویر هستند که در داخل تصویر ذخیره می‌شوند. برای مثال تصویری که شما با تلفن همراه خود می‌گیرید حاوی داده‌هایی مانند تاریخ و زمان ثبت تصویر، اطلاعات دوربین ثبت کننده تصویر و ... می‌باشد که وجود آن‌ها برای نمایش تصویر در وبسایت‌ها ضرورتی ندارد و فقط باعث بالاتر رفتن حجم این تصاویر می‌شود. این اطلاعات در حدی هستند که گاهی اوقات حجم آن‌ها به 40 کیلوبایت نیز می‌رسد و شما با حذف این داده‌ها می‌توانید حجم تصویر خود را 40 کیلوبایت کمتر کنید. شما می‌توانید از ابزارهای آنلاین برای نمایش، ویرایش و حذف این داده‌ها استفاده کنید.

تغییر اندازه تصاویر

تغییر اندازه تصاویر یکی از موثر‌ترین راه‌ها برای کاهش حجم تصاویر است. تصور کنید شما یک تصویر به طول و عرض 2000 پیکسل برای نمایش در یک از قسمت از وبسایتتان دارید. این قسمت از وبسایت یک جعبه به طول 500 پیکسل (در بزرگترین حالت خود) می‌باشد. توجه کنید که هیچ نیازی نیست که تصویری به طول 2000 پیکسلی را در یک جعبه به طول 500 پیکسل به نمایش بگذارید. شما به راحتی می‌توانید سایز این تصویر را مطابق اندازه جعبه خود تغییر دهید و در نهایت از حجم تصویر خود بکاهید. یادتان باشد هیچ نیازی به نمایش یک تصویر بزرگتر در یک جعبه کوچک‌تر وجود ندارد و شما باید مطابق با اندازه محل نمایش تصویر، اندازه تصویر خود را تنظیم کنید.

کاهش کیفیت تصویر

برخی از فرمت‌ها مانند فرمت JPEG این قابلیت را به شما می‌دهند تا کیفیت تصویر خود را انتخاب کنید و مطابق این کیفیت یک خروجی از تصویر دریافت کنید. شما با استفاده از این خصوصیت به راحتی می‌توانید حجم تصاویر خود را کاهش دهید. هیچ نیازی به خروجی با بالاترین کیفیت (100) نیست بلکه می‌توان تصاویر را با کیفیت پایین‌تر (در محدوده 60 تا 80) نیز خروجی گرفت. البته باید توجه کنید که هر چه این رقم پایین‌تر باشد کیفیت تصویر شما نیز کمتر می‌شود اما شما می‌توانید عددی را برای تصویر خود پیدا کنید که با این تغییر کیفیت به چشم کاربر نهایی محسوس نباشد. در تصاویر زیر 3 نمونه از خروجی با کیفیت‌های مختلف برای شما نشان داده شده است.

کیفیت ۱۰۰٪ با حجم ۲۲۷ کیلوبایت
کیفیت ۱۰۰٪ با حجم ۲۲۷ کیلوبایت
کیفیت ۸۰٪ با حجم ۶۰ کیلوبایت
کیفیت ۸۰٪ با حجم ۶۰ کیلوبایت
کیفیت ۲۵٪ با حجم ۲۰ کیلوبایت
کیفیت ۲۵٪ با حجم ۲۰ کیلوبایت

همانطور که مشاهده می‌کنید، با کاهش 20 درصدی کیفیت بدون تغییر محسوس در کیفیت تصویر نمایش داده شده می‌توان حجم تصویر را تا 74 درصد کاهش داد. تصویر با کیفیت 25% حتی حجم کمتری دارد اما در مقابل آن کیفیت پایین تصویر کاملا مشهود است در نتیجه به عنوان یک عکس مناسب برای نمایش کاربردی ندارد!

فشرده سازی تصاویر

فشرده سازی یکی دیگر از راه‌های کاهش حجم تصویر می‌باشد که معمولا با تغییر اندازه یا تغییر کیفیت تصویر به اشتباه گرفته می‌شود. فشرده سازی در واقع به معنی کاهش حجم تصویر بدون تغییر در اندازه و کیفیت تصویر است. برای مثال شما از طریق این وبسایت می‌توانید حجم تصاویر PNG خود را تا 75 درصد کاهش دهید در صورتی که این فرمت یک فرمت بدون فشرده سازی است و این تغییر حجم هیچ تاثیری در کیفیت تصویر خروجی ندارد.


مطابق راهکارهایی که تا اینجا با آن‌ها آشنا شدید، به راحتی می‌توانید حجم تصاویر مورد استفاده در وبسایت مورد نظرتان را کاهش دهید و در نتیجه حس بهتری را در تجربه کاربری به کاربران خود منتقل کنید. یکی از بهترین ابزارهای آنلاین که برای فشرده سازی، بهینه سازی، تغییر در اندازه، کیفیت و فرمت تصاویر استفاده می‌شود squash است که توسط تیم گوگل پیاده سازی شده است. شما با استفاده از این ابزار می‌توانید به راحتی و بین دو فرمت، دو نوع تنظیمات متخلف و یا تصویر اصلی و تصویر فشرده‌سازی شده خود مقایسه ظاهری انجام دهید تا بتوانید بهترین تنظیمات ممکن را از تصویر مورد نظر خود بگیرید. پیشنهاد می‌کنم حتما از این ابزار استفاده کنید.


در این پست تلاش کردیم تا شما را با راهکارهای مختلفی برای کاهش حجم تصاویر آشنا کنیم. محتواهای تصویری بین 60 تا 85 درصد از ترافیک اینترنت را تشکیل می‌دهد و حتما کاهش حجم آن‌ها باعث افزایش سرعت وبسایتتان می‌شود.

در پست بعدی در مورد HTTP Caching صحبت خواهیم کرد. اگر علاقه‌مندید تا پست بعدی ما را بخوانید، از این لینک استفاده کنید.

اگر در مورد این مطلب سوال، نظر یا پیشنهادی دارید لطفا با ما به اشتراک بگذارید. همچنین منتظر پست‌های آتی ما در زمینه بهبود کارایی در فرانت‌اند باشید.

بهینه سازیکاراییperformanceفرانت اندfront end
۲
۳
محمد صالح فدایی
محمد صالح فدایی
توسعه دهنده و علاقه مند به مباحث Performance و UX در Front-End
شاید از این پست‌ها خوشتان بیاید