ইমেজ কর্মক্ষমতা

ছবিগুলি প্রায়শই ওয়েবে সবচেয়ে ভারী এবং সবচেয়ে প্রচলিত সম্পদ। ফলস্বরূপ, ইমেজ অপ্টিমাইজ করা উল্লেখযোগ্যভাবে আপনার ওয়েবসাইটে কর্মক্ষমতা উন্নত করতে পারে। বেশিরভাগ ক্ষেত্রে, ছবিগুলি অপ্টিমাইজ করার অর্থ হল কম বাইট পাঠিয়ে নেটওয়ার্কের সময় কমানো, তবে আপনি ব্যবহারকারীর ডিভাইসের জন্য সঠিক আকারের ছবি পরিবেশন করে ব্যবহারকারীকে পাঠানো বাইটের পরিমাণও অপ্টিমাইজ করতে পারেন।

<img> অথবা <picture> উপাদান , অথবা CSS background-image প্রপার্টি ব্যবহার করে একটি পৃষ্ঠায় ছবি যোগ করা যেতে পারে।

ছবির আকার

ইমেজ রিসোর্স ব্যবহার করার সময় আপনি যে প্রথম অপ্টিমাইজেশনটি সম্পাদন করতে পারেন তা হল সঠিক আকারে ইমেজ প্রদর্শন করা—এই ক্ষেত্রে, সাইজ শব্দটি একটি ছবির মাত্রা বোঝায়। অন্য কোন ভেরিয়েবল বিবেচনা না করে, একটি 500 পিক্সেল বাই 500 পিক্সেল কন্টেইনারে প্রদর্শিত একটি চিত্রটি সর্বোত্তমভাবে 500 পিক্সেল বাই 500 পিক্সেল আকারে হবে৷ উদাহরণস্বরূপ, একটি বর্গাকার 1000 পিক্সেল চিত্র ব্যবহার করার অর্থ হল ছবিটি প্রয়োজনের তুলনায় দ্বিগুণ বড়।

যাইহোক, সঠিক চিত্রের আকার নির্বাচন করার সাথে জড়িত অনেকগুলি ভেরিয়েবল রয়েছে, যার ফলে প্রতিটি ক্ষেত্রে সঠিক চিত্রের আকার বেছে নেওয়ার কাজটি বেশ জটিল হয়ে ওঠে। 2010 সালে, যখন iPhone 4 প্রকাশ করা হয়েছিল, তখন স্ক্রীন রেজোলিউশন (640x960) ছিল iPhone 3 (320x480) এর দ্বিগুণ। যাইহোক, iPhone 4 এর স্ক্রীনের শারীরিক আকার মোটামুটি iPhone 3 এর মতোই ছিল।

উচ্চ রেজোলিউশনে সবকিছু প্রদর্শন করলে পাঠ্য এবং চিত্রগুলি উল্লেখযোগ্যভাবে ছোট হয়ে যেত - তাদের আগের আকারের অর্ধেক সঠিক। পরিবর্তে, 1 পিক্সেল 2 ডিভাইস পিক্সেল হয়ে গেছে। একে ডিভাইস পিক্সেল রেশিও (DPR) বলা হয়। iPhone 4—এবং এর পরে প্রকাশিত অনেক iPhone মডেল-এর DPR ছিল 2।

পূর্বের উদাহরণটি পুনর্বিবেচনা করে, যদি ডিভাইসটির একটি DPR 2 থাকে এবং চিত্রটি 500 পিক্সেল বাই 500 পিক্সেল কন্টেনারে প্রদর্শিত হয়, তাহলে একটি বর্গাকার 1000 পিক্সেল চিত্র (যাকে অন্তর্নিহিত আকার হিসাবে উল্লেখ করা হয়) এখন সর্বোত্তম আকার। একইভাবে, যদি ডিভাইসটির একটি DPR 3 থাকে, তাহলে একটি বর্গাকার 1500 পিক্সেল চিত্রটি সর্বোত্তম আকার হবে৷

srcset

<img> উপাদানটি srcset বৈশিষ্ট্য সমর্থন করে, যা আপনাকে সম্ভাব্য চিত্র উত্সগুলির একটি তালিকা নির্দিষ্ট করতে দেয় যা ব্রাউজার ব্যবহার করতে পারে। নির্দিষ্ট করা প্রতিটি ছবির উৎসে অবশ্যই ছবির URL এবং একটি প্রস্থ বা পিক্সেল ঘনত্বের বর্ণনা অন্তর্ভুক্ত থাকতে হবে।

<img
  alt="An image"
  width="500"
  height="500"
  src="/image-500.jpg"
  srcset="/image-500.jpg 1x, /image-1000.jpg 2x, /image-1500.jpg 3x"
>

পূর্ববর্তী HTML স্নিপেট পিক্সেল ঘনত্ব বর্ণনাকারী ব্যবহার করে ব্রাউজারকে 1 এর DPR সহ ডিভাইসে image-500.png , 2 এর DPR সহ ডিভাইসে image-1000.jpg এবং ডিভাইসে image-1500.jpg ব্যবহার করার জন্য ইঙ্গিত দেয় 3 এর একটি ডিপিআর।

যদিও এই সব কাটা এবং শুষ্ক মনে হতে পারে, একটি প্রদত্ত পৃষ্ঠার জন্য সর্বোত্তম চিত্র নির্বাচন করার ক্ষেত্রে একটি স্ক্রিনের ডিপিআর একমাত্র বিবেচনা নয়। পৃষ্ঠার বিন্যাস এখনও অন্য বিবেচনা.

sizes

পূর্ববর্তী সমাধানটি তখনই কাজ করে যদি আপনি সমস্ত ভিউপোর্টে একই CSS পিক্সেল আকারে চিত্র প্রদর্শন করেন। অনেক ক্ষেত্রে, ব্যবহারকারীর ডিভাইসের উপর নির্ভর করে একটি পৃষ্ঠার বিন্যাস-এবং এর সাথে কন্টেইনারের আকার-পরিবর্তন হয়।

sizes অ্যাট্রিবিউট আপনাকে সোর্স সাইজের একটি সেট নির্দিষ্ট করতে দেয়, যেখানে প্রতিটি সোর্স সাইজ একটি মিডিয়া অবস্থা এবং একটি মান নিয়ে গঠিত। sizes অ্যাট্রিবিউট সিএসএস পিক্সেলে ইমেজের ইচ্ছাকৃত ডিসপ্লে সাইজ বর্ণনা করে। srcset প্রস্থ বর্ণনাকারীর সাথে একত্রিত হলে, ব্রাউজার ব্যবহারকারীর ডিভাইসের জন্য কোন ছবির উৎসটি সেরা তা বেছে নিতে পারে।

<img
  alt="An image"
  width="500"
  height="500"
  src="/image-500.jpg"
  srcset="/image-500.jpg 500w, /image-1000.jpg 1000w, /image-1500.jpg 1500w"
  sizes="(min-width: 768px) 500px, 100vw"
>

পূর্ববর্তী এইচটিএমএল স্নিপেটে, srcset বৈশিষ্ট্যটি কমা দ্বারা পৃথক করে ব্রাউজারটি বেছে নিতে পারে এমন চিত্র প্রার্থীদের একটি তালিকা নির্দিষ্ট করে। তালিকার প্রতিটি প্রার্থীর মধ্যে ছবির URL থাকে, তারপরে একটি সিনট্যাক্স থাকে যা চিত্রের অন্তর্নিহিত প্রস্থকে নির্দেশ করে। একটি চিত্রের অন্তর্নিহিত আকার হল এর মাত্রা। উদাহরণস্বরূপ, 1000w এর একটি বর্ণনাকারী নির্দেশ করে যে চিত্রটির অন্তর্নিহিত প্রস্থ 1000 পিক্সেল প্রশস্ত।

এই তথ্য ব্যবহার করে, ব্রাউজার sizes অ্যাট্রিবিউটে মিডিয়া কন্ডিশনের মূল্যায়ন করে এবং — এই ক্ষেত্রে — নির্দেশ দেওয়া হয় যে ডিভাইসের ভিউপোর্টের প্রস্থ 768 পিক্সেলের বেশি হলে, ছবিটি 500 পিক্সেলের প্রস্থে প্রদর্শিত হবে। ছোট ডিভাইসে, চিত্রটি 100vw অথবা সম্পূর্ণ ভিউপোর্ট প্রস্থে প্রদর্শিত হয়।

ব্রাউজার তারপরে সর্বোত্তম চিত্র খুঁজে পেতে srcset চিত্র উত্সগুলির তালিকার সাথে এই তথ্যগুলিকে একত্রিত করতে পারে। উদাহরণস্বরূপ, যদি ব্যবহারকারী একটি মোবাইল ডিভাইসে থাকে যার স্ক্রীন প্রস্থ 320 পিক্সেলের 3 এর DPR সহ, চিত্রটি 320 CSS pixels x 3 DPR = 960 device pixels প্রদর্শিত হয়। এই উদাহরণে, নিকটতম আকারের চিত্রটি হবে image-1000.jpg যার অন্তর্নিহিত প্রস্থ 1000 পিক্সেল ( 1000w )।

ফাইল ফরম্যাট

ব্রাউজারগুলি বিভিন্ন ইমেজ ফাইল ফরম্যাট সমর্থন করে। WebP এবং AVIF এর মত আধুনিক ইমেজ ফরম্যাট PNG বা JPEG এর চেয়ে ভালো কম্প্রেশন প্রদান করতে পারে, যা আপনার ইমেজ ফাইলের আকারকে ছোট করে এবং তাই ডাউনলোড করতে কম সময় নেয়। আধুনিক বিন্যাসে ছবি পরিবেশন করার মাধ্যমে, আপনি একটি সম্পদের লোডের সময় কমাতে পারেন, যার ফলে একটি নিম্নতর বৃহৎ কন্টেন্টফুল পেইন্ট (LCP) হতে পারে।

WebP একটি ব্যাপকভাবে সমর্থিত ফর্ম্যাট যা সমস্ত আধুনিক ব্রাউজারে কাজ করে। WebP-এর প্রায়শই JPEG, PNG, বা GIF এর চেয়ে ভাল কম্প্রেশন থাকে, যা ক্ষতিকর এবং ক্ষতিহীন উভয় কম্প্রেশন অফার করে। ক্ষতিকর কম্প্রেশন ব্যবহার করার সময়ও WebP আলফা চ্যানেলের স্বচ্ছতাকেও সমর্থন করে—যেটি JPEG কোডেক অফার করে না এমন একটি বৈশিষ্ট্য।

AVIF হল একটি নতুন ইমেজ ফরম্যাট, এবং যদিও এটি WebP এর মত ব্যাপকভাবে সমর্থিত নয়, এটি ব্রাউজার জুড়ে যুক্তিসঙ্গতভাবে শালীন সমর্থন উপভোগ করে। AVIF ক্ষতিকারক এবং ক্ষতিহীন উভয় কম্প্রেশন সমর্থন করে এবং কিছু ক্ষেত্রে JPEG-এর তুলনায় পরীক্ষাগুলি 50%-এর বেশি সঞ্চয় দেখিয়েছে। AVIF ওয়াইড কালার গামুট (WCG) এবং হাই ডায়নামিক রেঞ্জ (HDR) বৈশিষ্ট্যও অফার করে।

কম্প্রেশন

যেখানে চিত্রগুলি উদ্বিগ্ন, সেখানে দুটি ধরণের সংকোচন রয়েছে:

  1. ক্ষতিকর কম্প্রেশন
  2. ক্ষতিহীন কম্প্রেশন

ক্ষতিকারক কম্প্রেশন কোয়ান্টাইজেশনের মাধ্যমে চিত্রের যথার্থতা হ্রাস করে কাজ করে এবং ক্রোমা সাবস্যাম্পলিং ব্যবহার করে অতিরিক্ত রঙের তথ্য বাতিল করা যেতে পারে। ক্ষতিকারক সংকোচন উচ্চ-ঘনত্বের চিত্রগুলিতে প্রচুর শব্দ এবং রঙের ক্ষেত্রে সবচেয়ে কার্যকর—সাধারণত একই বিষয়বস্তু সহ ফটো বা চিত্র। এর কারণ হল ক্ষতিকর কম্প্রেশন দ্বারা উত্পাদিত শিল্পকর্মগুলি এই ধরনের বিস্তারিত চিত্রগুলিতে লক্ষ্য করার সম্ভাবনা অনেক কম। যাইহোক, লাইন আর্ট, একইভাবে স্টার্ক ডিটেইলস বা টেক্সটের মতো তীক্ষ্ণ প্রান্তযুক্ত চিত্রাবলীর সাথে ক্ষতিকর কম্প্রেশন কম কার্যকর হতে পারে। ক্ষতিকর কম্প্রেশন JPEG, WebP, এবং AVIF ছবিতে প্রয়োগ করা যেতে পারে।

লসলেস কম্প্রেশন কোনো ডেটা ক্ষতি ছাড়াই একটি ইমেজ কম্প্রেস করে ফাইলের আকার কমিয়ে দেয়। লসলেস কম্প্রেশন তার প্রতিবেশী পিক্সেল থেকে পার্থক্যের উপর ভিত্তি করে একটি পিক্সেল বর্ণনা করে। GIF, PNG, WebP, এবং AVIF ইমেজ ফরম্যাটের জন্য লসলেস কম্প্রেশন ব্যবহার করা হয়।

আপনি Squosh , ImageOptim , বা একটি ইমেজ অপ্টিমাইজেশান পরিষেবা ব্যবহার করে আপনার ছবিগুলিকে সংকুচিত করতে পারেন৷ কম্প্রেস করার সময়, সব ক্ষেত্রে উপযুক্ত একটি সার্বজনীন সেটিং নেই। যতক্ষণ না আপনি চিত্রের গুণমান এবং ফাইলের আকারের মধ্যে একটি ভাল আপস খুঁজে না পান ততক্ষণ পর্যন্ত প্রস্তাবিত পদ্ধতিটি বিভিন্ন কম্প্রেশন স্তরের সাথে পরীক্ষা করা হবে। কিছু উন্নত ইমেজ অপ্টিমাইজেশান পরিষেবাগুলি স্বয়ংক্রিয়ভাবে আপনার জন্য এটি করতে পারে, তবে সমস্ত ব্যবহারকারীর জন্য আর্থিকভাবে কার্যকর নাও হতে পারে৷

<picture> উপাদান

<picture> উপাদানটি আপনাকে একাধিক ইমেজ প্রার্থী নির্দিষ্ট করার ক্ষেত্রে আরও নমনীয়তা দেয়:

<picture>
  <source type="image/avif" srcset="image.avif">
  <source type="image/webp" srcset="image.webp">
  <img
    alt="An image"
    width="500"
    height="500"
    src="/image.jpg"
  >
</picture>

আপনি যখন <picture> উপাদানের মধ্যে <source> উপাদান(গুলি) ব্যবহার করেন, আপনি AVIF এবং WebP চিত্রগুলির জন্য সমর্থন যোগ করতে পারেন, কিন্তু ব্রাউজারটি আধুনিক বিন্যাস সমর্থন না করলে আরও সামঞ্জস্যপূর্ণ লিগ্যাসি চিত্র বিন্যাসে ফিরে যেতে পারেন। এই পদ্ধতির সাহায্যে, ব্রাউজার প্রথম <source> উপাদানটি বেছে নেয় যা মেলে। যদি এটি সেই বিন্যাসে চিত্রটিকে রেন্ডার করতে পারে তবে এটি সেই চিত্রটি ব্যবহার করে। অন্যথায়, ব্রাউজার পরবর্তী নির্দিষ্ট <source> উপাদানে চলে যায়। পূর্ববর্তী HTML স্নিপেটে, AVIF ফর্ম্যাট WebP ফর্ম্যাটের উপর অগ্রাধিকার নেয়, যদি AVIF বা WebP সমর্থিত না হয় তাহলে JPEG ফর্ম্যাটে ফিরে আসে৷

একটি <picture> উপাদানটির ভিতরে একটি <img> উপাদান প্রয়োজন। alt , width , এবং height বৈশিষ্ট্যগুলি <img> -এ সংজ্ঞায়িত করা হয় এবং যেটি <source> নির্বাচন করা হোক না কেন ব্যবহার করা হয়।

<source> উপাদানটি media , srcset এবং sizes বৈশিষ্ট্যগুলিকেও সমর্থন করে। একইভাবে আগের <img> উদাহরণের মতো, এগুলি ব্রাউজারকে নির্দেশ করে যে বিভিন্ন ভিউপোর্টে কোন ছবি নির্বাচন করতে হবে।

<picture>
  <source
    media="(min-resolution: 1.5x)"
    srcset="/image-1000.jpg 1000w, /image-1500.jpg 1500w"
    sizes="(min-width: 768px) 500px, 100vw"
  >
  <img
    alt="An image"
    width="500"
    height="500"
    src="/image-500.jpg"
  >
</picture>

media বৈশিষ্ট্য একটি মিডিয়া শর্ত লাগে। পূর্ববর্তী উদাহরণে, ডিভাইসের DPR মিডিয়া শর্ত হিসাবে ব্যবহৃত হয়। 1.5 এর চেয়ে বেশি বা সমান DPR সহ যেকোনো ডিভাইস প্রথম <source> উপাদান ব্যবহার করবে। <source> উপাদানটি ব্রাউজারকে বলে যে, 768 পিক্সেলের চেয়ে চওড়া ভিউপোর্ট সহ ডিভাইসগুলিতে, নির্বাচিত চিত্র প্রার্থী 500 পিক্সেল চওড়ায় প্রদর্শিত হয়। ছোট ডিভাইসে, এটি পুরো ভিউপোর্ট প্রস্থ নেয়। media এবং srcset বৈশিষ্ট্যগুলি একত্রিত করে, আপনি কোন চিত্রটি ব্যবহার করবেন তার উপর সূক্ষ্ম নিয়ন্ত্রণ রাখতে পারেন।

এটি নিম্নলিখিত সারণীতে চিত্রিত করা হয়েছে, যেখানে বেশ কয়েকটি ভিউপোর্ট প্রস্থ এবং ডিভাইস পিক্সেল অনুপাত মূল্যায়ন করা হয়েছে:

ভিউপোর্ট প্রস্থ (পিক্সেল) 1 ডিপিআর 1.5 ডিপিআর 2 ডিপিআর 3 ডিপিআর
320 500.jpg 500.jpg 500.jpg 1000.jpg
480 500.jpg 500.jpg 1000.jpg 1500.jpg
560 500.jpg 1000.jpg 1000.jpg 1500.jpg
1024 500.jpg 1000.jpg 1000.jpg 1500.jpg
1920 500.jpg 1000.jpg 1000.jpg 1500.jpg

1 এর ডিপিআর সহ ডিভাইসগুলি image-500.jpg ইমেজ ডাউনলোড করে, যার মধ্যে বেশিরভাগ ডেস্কটপ ব্যবহারকারী-যারা 500 পিক্সেল চওড়া একটি বহিরাগত আকারে ছবিটি দেখেন। অন্যদিকে, 3-এর DPR সহ মোবাইল ব্যবহারকারীরা একটি সম্ভাব্য বড় image-1500.jpg ডাউনলোড করে — একই ছবি 3-এর DPR সহ ডেস্কটপ ডিভাইসে ব্যবহৃত হয়।

<picture>
  <source
    media="(min-width: 561px) and (min-resolution: 1.5x)"
    srcset="/image-1000.jpg 1000w, /image-1500.jpg 1500w"
    sizes="(min-width: 768px) 500px, 100vw"
  >
  <source
    media="(max-width: 560px) and (min-resolution: 1.5x)"
    srcset="/image-1000-sm.jpg 1000w, /image-1500-sm.jpg 1500w"
    sizes="(min-width: 768px) 500px, 100vw"
  >
  <img
    alt="An image"
    width="500"
    height="500"
    src="/image-500.jpg"
  >
</picture>

এই উদাহরণে, উচ্চ ডিপিআর সহ প্রশস্ত ডিভাইসগুলির জন্য বিভিন্ন চিত্র ব্যবহার করার জন্য একটি অতিরিক্ত <source> উপাদান অন্তর্ভুক্ত করার জন্য <picture> উপাদানটি সামঞ্জস্য করা হয়েছে:

ভিউপোর্ট প্রস্থ (পিক্সেল) 1 ডিপিআর 1.5 ডিপিআর 2 ডিপিআর 3 ডিপিআর
320 500.jpg 500.jpg 1000-sm.jpg 1000-sm.jpg
480 500.jpg 500.jpg 1000-sm.jpg 1500-sm.jpg
560 500.jpg 1000-sm.jpg 1000-sm.jpg 1500-sm.jpg
1024 500.jpg 1000.jpg 1000.jpg 1500.jpg
1920 500.jpg 1000.jpg 1000.jpg 1500.jpg

এই অতিরিক্ত ক্যোয়ারীটির মাধ্যমে, আপনি দেখতে পাচ্ছেন যে image-1000-sm.jpg এবং image-1500-sm.jpg ছোট ভিউপোর্টে প্রদর্শিত হচ্ছে। এই অতিরিক্ত তথ্যটি আপনাকে ছবিগুলিকে আরও সংকুচিত করতে দেয়, যেহেতু কম্প্রেশন আর্টিফ্যাক্টগুলি সেই আকার এবং ঘনত্বে খুব বেশি দৃশ্যমান নয়, পাশাপাশি ডেস্কটপ ডিভাইসগুলিতে চিত্রের গুণমানের সাথে আপস করে না।

বিকল্পভাবে, srcset এবং media বৈশিষ্ট্যগুলি সামঞ্জস্য করে, আপনি ছোট ভিউপোর্টে বড় ছবি পরিবেশন করা এড়াতে পারেন:

<picture>
  <source
    media="(min-width: 561px)"
    srcset="/image-500.jpg, /image-1000.jpg 2x, /image-1500.jpg 3x"
  >
  <source
    media="(max-width: 560px)"
    srcset="/image-500.jpg 1x, /image-1000.jpg 2x"
  >
  <img
    alt="An image"
    width="500"
    height="500"
    src="/image-500.jpg"
  >
</picture>

পূর্ববর্তী এইচটিএমএল স্নিপেটে, ডিভাইস পিক্সেল অনুপাত বর্ণনাকারীর পক্ষে প্রস্থ বর্ণনাকারীগুলি সরানো হয়েছে। একটি মোবাইল ডিভাইসে পরিবেশিত ছবিগুলি /image-500.jpg বা /image-1000.jpg এর মধ্যে সীমাবদ্ধ, এমনকি 3 এর DPR সহ ডিভাইসেও৷

কীভাবে জটিলতা পরিচালনা করবেন

প্রতিক্রিয়াশীল চিত্রগুলির সাথে কাজ করার সময়, আপনি প্রতিটি চিত্রের জন্য বিভিন্ন আকারের বৈচিত্র এবং বিন্যাসের সাথে নিজেকে খুঁজে পেতে পারেন। পূর্ববর্তী উদাহরণে, প্রতিটি আকারের বৈচিত্র ব্যবহার করা হয়, তবে AVIF এবং WebP বাদ দিন। আপনার কতগুলি বৈকল্পিক থাকা উচিত? অনেক ইঞ্জিনিয়ারিং সমস্যার মতো, উত্তরটি "এটি নির্ভর করে" হতে থাকে।

সর্বোত্তম ফিট ডেলিভারি করার জন্য অনেকগুলি বৈচিত্র্য থাকা লোভনীয় হতে পারে, প্রতিটি অতিরিক্ত চিত্র বৈকল্পিক একটি খরচে আসে এবং ব্রাউজার ক্যাশের কম দক্ষ ব্যবহার করে। শুধুমাত্র একটি ভেরিয়েন্টের সাথে, প্রতিটি ব্যবহারকারী একই চিত্র গ্রহণ করে, তাই এটি খুব দক্ষতার সাথে ক্যাশে করা যেতে পারে।

অন্য দিকে, যদি অনেক বৈচিত্র্য থাকে, প্রতিটি বৈকল্পিক অন্য ক্যাশে এন্ট্রি প্রয়োজন। সার্ভারের খরচ বাড়তে পারে এবং কার্যক্ষমতা হ্রাস করতে পারে যদি ভেরিয়েন্টের ক্যাশে এন্ট্রির মেয়াদ শেষ হয়ে যায়, এবং ছবিটি আবার অরিজিন সার্ভার থেকে আনতে হবে।

এটি ছাড়াও, আপনার HTML নথির আকার প্রতিটি পরিবর্তনের সাথে বৃদ্ধি পায়। আপনি প্রতিটি ছবির জন্য একাধিক কিলোবাইট এইচটিএমএল শিপিং করতে পারেন।

অনুরোধ Accept শিরোনাম উপর ভিত্তি করে ছবি পরিবেশন

Accept HTTP রিকোয়েস্ট হেডার সার্ভারকে জানায় যে ব্যবহারকারীর ব্রাউজার কোন ধরনের বিষয়বস্তু বুঝতে পারে। এই তথ্যটি আপনার সার্ভার দ্বারা আপনার HTML প্রতিক্রিয়াগুলিতে অতিরিক্ত বাইট যোগ না করে সর্বোত্তম চিত্র বিন্যাস পরিবেশন করতে ব্যবহার করা যেতে পারে।

if (request.headers.accept) {
  if (request.headers.accept.includes('image/avif')) {
    return reply.from('image.avif');
  } else if (request.headers.accept.includes('image/webp')) {
    return reply.from('image.webp');
  }
}

return reply.from('image.jpg');

পূর্ববর্তী HTML স্নিপেট হল কোডের একটি সরলীকৃত সংস্করণ যা আপনি আপনার সার্ভারের JavaScript ব্যাকএন্ডে যোগ করতে পারেন এবং সর্বোত্তম চিত্র বিন্যাসটি চয়ন করতে এবং পরিবেশন করতে পারেন৷ যদি অনুরোধ Accept শিরোনামে image/avif অন্তর্ভুক্ত থাকে, তাহলে AVIF চিত্রটি পরিবেশিত হয়। অন্যথায়, যদি Accept হেডারে image/webp অন্তর্ভুক্ত থাকে, তাহলে WebP ইমেজ পরিবেশিত হয়। যদি এই শর্তগুলির কোনটিই সত্য না হয়, তাহলে JPEG ইমেজ পরিবেশিত হয়।

আপনি প্রায় প্রতিটি ধরণের ওয়েব সার্ভারে Accept রিকোয়েস্ট হেডারের বিষয়বস্তুর উপর ভিত্তি করে প্রতিক্রিয়াগুলি পরিবর্তন করতে পারেন—উদাহরণস্বরূপ, আপনি mod_rewrite ব্যবহার করে Accept হেডারের উপর ভিত্তি করে Apache সার্ভারে ইমেজ অনুরোধগুলি পুনরায় লিখতে পারেন।

এটি একটি ইমেজ কন্টেন্ট ডেলিভারি নেটওয়ার্ক (CDN) এ আপনি যে আচরণ পাবেন তার বিপরীত নয়। ইমেজ সিডিএন হল ইমেজ অপ্টিমাইজ করার জন্য এবং ব্যবহারকারীর ডিভাইস এবং ব্রাউজারের উপর ভিত্তি করে সর্বোত্তম ফর্ম্যাট পাঠানোর জন্য চমৎকার সমাধান।

মূল বিষয় হল একটি ভারসাম্য খুঁজে বের করা, একটি যুক্তিসঙ্গত সংখ্যক ইমেজ প্রার্থী তৈরি করা এবং ব্যবহারকারীর অভিজ্ঞতার উপর প্রভাব পরিমাপ করা। বিভিন্ন ছবি বিভিন্ন ফলাফল দিতে পারে এবং প্রতিটি ছবিতে প্রয়োগ করা অপ্টিমাইজেশানগুলি পৃষ্ঠার মধ্যে তার আকার এবং আপনার ব্যবহারকারীরা যে ডিভাইসগুলি ব্যবহার করছেন তার উপর নির্ভর করে৷ উদাহরণস্বরূপ, একটি ইকমার্স পণ্য তালিকা পৃষ্ঠায় থাম্বনেইল চিত্রগুলির চেয়ে একটি পূর্ণ-প্রস্থের নায়ক চিত্রের জন্য আরও বেশি রূপের প্রয়োজন হতে পারে।

অলস লোড হচ্ছে

loading অ্যাট্রিবিউট ব্যবহার করে ভিউপোর্টে দেখা গেলে ব্রাউজারকে অলস লোড করা ছবি বলা সম্ভব। lazy একটি বৈশিষ্ট্যের মান ব্রাউজারকে বলে যে ছবিটি ভিউপোর্টে (বা কাছাকাছি) না হওয়া পর্যন্ত ডাউনলোড না করতে। এটি ব্যান্ডউইথ সংরক্ষণ করে, ব্রাউজারকে ইতিমধ্যেই ভিউপোর্টে থাকা গুরুত্বপূর্ণ বিষয়বস্তু রেন্ডার করার জন্য প্রয়োজনীয় সংস্থানগুলিকে অগ্রাধিকার দেওয়ার অনুমতি দেয়৷

decoding

decoding অ্যাট্রিবিউট ব্রাউজারকে বলে যে এটি কীভাবে ছবিটি ডিকোড করা উচিত। async একটি মান ব্রাউজারকে বলে যে ইমেজটি অ্যাসিঙ্ক্রোনাসভাবে ডিকোড করা যেতে পারে, সম্ভবত অন্যান্য সামগ্রী রেন্ডার করার সময়কে উন্নত করে। sync একটি মান ব্রাউজারকে বলে যে চিত্রটি অন্যান্য সামগ্রীর মতো একই সময়ে উপস্থাপন করা উচিত। auto ডিফল্ট মান ব্রাউজারকে সিদ্ধান্ত নিতে দেয় যে ব্যবহারকারীর জন্য কোনটি সেরা।

ইমেজ ডেমো

আপনার জ্ঞান পরীক্ষা করুন

কোন চিত্র বিন্যাস ক্ষতিহীন কম্প্রেশন সমর্থন করে?

জিআইএফ
সঠিক!
জেপিইজি।
আবার চেষ্টা করুন
পিএনজি।
সঠিক!
ওয়েবপি
সঠিক!
এভিআইএফ।
সঠিক!

কোন চিত্র বিন্যাস ক্ষতিকারক কম্প্রেশন সমর্থন করে?

জিআইএফ
আবার চেষ্টা করুন যদিও GIF ফর্ম্যাট শুধুমাত্র 256 রঙের একটি সীমিত প্যালেট সমর্থন করে, GIF তে রূপান্তর করার আগে ক্ষতিকারক এনকোডিং করা আবশ্যক।
জেপিইজি।
সঠিক!
পিএনজি।
আবার চেষ্টা করুন
ওয়েবপি
সঠিক!
এভিআইএফ।
সঠিক!

প্রস্থ বর্ণনাকারী (উদাহরণস্বরূপ, 1000w ) ব্রাউজারকে একটি srcset বৈশিষ্ট্যে নির্দিষ্ট করা একটি চিত্র প্রার্থী সম্পর্কে কী বলে?

ছবির বহির্মুখী প্রস্থ—অর্থাৎ, পৃষ্ঠায় শৈলী প্রয়োগ করার পরে লেআউটে চিত্রের মাত্রা
আবার চেষ্টা করুন
ইমেজের অন্তর্নিহিত প্রস্থ—অর্থাৎ, চিত্রেরই মাত্রা।
সঠিক!

sizes অ্যাট্রিবিউট ব্রাউজারকে একটি <img> উপাদান সম্পর্কে কী বলে যে এটি প্রয়োগ করা হয়েছে?

ব্যবহারকারীর বর্তমান ভিউপোর্টের মাত্রা বিবেচনা করে <img> এলিমেন্টের srcset এ কোন প্রার্থীকে লোড করা উচিত তা প্রকাশ করে এমন যুক্তি।
সঠিক!
<img> উপাদানের srcset বৈশিষ্ট্য থেকে লোড করা ছবির অন্তর্নিহিত প্রস্থ।
আবার চেষ্টা করুন

পরবর্তী: ভিডিও পারফরম্যান্স

যদিও ছবিগুলি ওয়েবে ব্যবহৃত সবচেয়ে প্রচলিত মিডিয়া টাইপ হতে পারে, তবে পারফরম্যান্সের ক্ষেত্রে আপনাকে মনে রাখতে হবে এমন একটি থেকে দূরে। ভিডিও হল ওয়েব জুড়ে ব্যবহৃত আরেকটি সাধারণ ধরনের মিডিয়া, এবং এর নিজস্ব পারফরম্যান্স বিবেচনার সাথে আসে। এই কোর্সের পরবর্তী মডিউলে , ভিডিওগুলি অপ্টিমাইজ করার এবং কীভাবে সেগুলিকে দক্ষতার সাথে লোড করা যায় সে সম্পর্কে কিছু কৌশল অন্বেষণ করুন৷

,

ছবিগুলি প্রায়শই ওয়েবে সবচেয়ে ভারী এবং সবচেয়ে প্রচলিত সম্পদ। ফলস্বরূপ, ইমেজ অপ্টিমাইজ করা উল্লেখযোগ্যভাবে আপনার ওয়েবসাইটে কর্মক্ষমতা উন্নত করতে পারে। বেশিরভাগ ক্ষেত্রে, ছবিগুলি অপ্টিমাইজ করার অর্থ হল কম বাইট পাঠিয়ে নেটওয়ার্কের সময় কমানো, তবে আপনি ব্যবহারকারীর ডিভাইসের জন্য সঠিক আকারের ছবি পরিবেশন করে ব্যবহারকারীকে পাঠানো বাইটের পরিমাণও অপ্টিমাইজ করতে পারেন।

<img> অথবা <picture> উপাদান , অথবা CSS background-image প্রপার্টি ব্যবহার করে একটি পৃষ্ঠায় ছবি যোগ করা যেতে পারে।

ছবির আকার

ইমেজ রিসোর্স ব্যবহার করার সময় আপনি যে প্রথম অপ্টিমাইজেশনটি সম্পাদন করতে পারেন তা হল সঠিক আকারে ইমেজ প্রদর্শন করা—এই ক্ষেত্রে, সাইজ শব্দটি একটি ছবির মাত্রা বোঝায়। অন্য কোন ভেরিয়েবল বিবেচনা না করে, একটি 500 পিক্সেল বাই 500 পিক্সেল কন্টেইনারে প্রদর্শিত একটি চিত্রটি সর্বোত্তমভাবে 500 পিক্সেল বাই 500 পিক্সেল আকারে হবে৷ উদাহরণস্বরূপ, একটি বর্গাকার 1000 পিক্সেল চিত্র ব্যবহার করার অর্থ হল ছবিটি প্রয়োজনের তুলনায় দ্বিগুণ বড়।

যাইহোক, সঠিক চিত্রের আকার নির্বাচন করার সাথে জড়িত অনেকগুলি ভেরিয়েবল রয়েছে, যার ফলে প্রতিটি ক্ষেত্রে সঠিক চিত্রের আকার বেছে নেওয়ার কাজটি বেশ জটিল হয়ে ওঠে। 2010 সালে, যখন iPhone 4 প্রকাশ করা হয়েছিল, তখন স্ক্রীন রেজোলিউশন (640x960) ছিল iPhone 3 (320x480) এর দ্বিগুণ। যাইহোক, iPhone 4 এর স্ক্রীনের শারীরিক আকার মোটামুটি iPhone 3 এর মতোই ছিল।

উচ্চ রেজোলিউশনে সবকিছু প্রদর্শন করলে পাঠ্য এবং চিত্রগুলি উল্লেখযোগ্যভাবে ছোট হয়ে যেত - তাদের আগের আকারের অর্ধেক সঠিক। পরিবর্তে, 1 পিক্সেল 2 ডিভাইস পিক্সেল হয়ে গেছে। একে ডিভাইস পিক্সেল রেশিও (DPR) বলা হয়। iPhone 4—এবং এর পরে প্রকাশিত অনেক iPhone মডেল-এর DPR ছিল 2।

পূর্বের উদাহরণটি পুনর্বিবেচনা করে, যদি ডিভাইসটির একটি DPR 2 থাকে এবং চিত্রটি 500 পিক্সেল বাই 500 পিক্সেল কন্টেনারে প্রদর্শিত হয়, তাহলে একটি বর্গাকার 1000 পিক্সেল চিত্র (যাকে অন্তর্নিহিত আকার হিসাবে উল্লেখ করা হয়) এখন সর্বোত্তম আকার। একইভাবে, যদি ডিভাইসটির একটি DPR 3 থাকে, তাহলে একটি বর্গাকার 1500 পিক্সেল চিত্রটি সর্বোত্তম আকার হবে৷

srcset

<img> উপাদানটি srcset বৈশিষ্ট্য সমর্থন করে, যা আপনাকে সম্ভাব্য চিত্র উত্সগুলির একটি তালিকা নির্দিষ্ট করতে দেয় যা ব্রাউজার ব্যবহার করতে পারে। নির্দিষ্ট করা প্রতিটি ছবির উৎসে অবশ্যই ছবির URL এবং একটি প্রস্থ বা পিক্সেল ঘনত্বের বর্ণনা অন্তর্ভুক্ত থাকতে হবে।

<img
  alt="An image"
  width="500"
  height="500"
  src="/image-500.jpg"
  srcset="/image-500.jpg 1x, /image-1000.jpg 2x, /image-1500.jpg 3x"
>

পূর্ববর্তী HTML স্নিপেট পিক্সেল ঘনত্ব বর্ণনাকারী ব্যবহার করে ব্রাউজারকে 1 এর DPR সহ ডিভাইসে image-500.png , 2 এর DPR সহ ডিভাইসে image-1000.jpg এবং ডিভাইসে image-1500.jpg ব্যবহার করার জন্য ইঙ্গিত দেয় 3 এর একটি ডিপিআর।

যদিও এই সব কাটা এবং শুষ্ক মনে হতে পারে, একটি প্রদত্ত পৃষ্ঠার জন্য সর্বোত্তম চিত্র নির্বাচন করার ক্ষেত্রে একটি স্ক্রিনের ডিপিআর একমাত্র বিবেচনা নয়। পৃষ্ঠার বিন্যাস এখনও অন্য বিবেচনা.

sizes

পূর্ববর্তী সমাধানটি তখনই কাজ করে যদি আপনি সমস্ত ভিউপোর্টে একই CSS পিক্সেল আকারে চিত্র প্রদর্শন করেন। অনেক ক্ষেত্রে, ব্যবহারকারীর ডিভাইসের উপর নির্ভর করে একটি পৃষ্ঠার বিন্যাস-এবং এর সাথে কন্টেইনারের আকার-পরিবর্তন হয়।

sizes অ্যাট্রিবিউট আপনাকে সোর্স সাইজের একটি সেট নির্দিষ্ট করতে দেয়, যেখানে প্রতিটি সোর্স সাইজ একটি মিডিয়া অবস্থা এবং একটি মান নিয়ে গঠিত। sizes অ্যাট্রিবিউট সিএসএস পিক্সেলে ইমেজের ইচ্ছাকৃত ডিসপ্লে সাইজ বর্ণনা করে। srcset প্রস্থ বর্ণনাকারীর সাথে একত্রিত হলে, ব্রাউজার ব্যবহারকারীর ডিভাইসের জন্য কোন ছবির উৎসটি সেরা তা বেছে নিতে পারে।

<img
  alt="An image"
  width="500"
  height="500"
  src="/image-500.jpg"
  srcset="/image-500.jpg 500w, /image-1000.jpg 1000w, /image-1500.jpg 1500w"
  sizes="(min-width: 768px) 500px, 100vw"
>

পূর্ববর্তী এইচটিএমএল স্নিপেটে, srcset বৈশিষ্ট্যটি কমা দ্বারা পৃথক করে ব্রাউজারটি বেছে নিতে পারে এমন চিত্র প্রার্থীদের একটি তালিকা নির্দিষ্ট করে। তালিকার প্রতিটি প্রার্থীর মধ্যে ছবির URL থাকে, তারপরে একটি সিনট্যাক্স থাকে যা চিত্রের অন্তর্নিহিত প্রস্থকে নির্দেশ করে। একটি চিত্রের অন্তর্নিহিত আকার হল এর মাত্রা। উদাহরণস্বরূপ, 1000w এর একটি বর্ণনাকারী নির্দেশ করে যে চিত্রটির অন্তর্নিহিত প্রস্থ 1000 পিক্সেল প্রশস্ত।

এই তথ্য ব্যবহার করে, ব্রাউজার sizes অ্যাট্রিবিউটে মিডিয়া কন্ডিশনের মূল্যায়ন করে এবং — এই ক্ষেত্রে — নির্দেশ দেওয়া হয় যে ডিভাইসের ভিউপোর্টের প্রস্থ 768 পিক্সেলের বেশি হলে, ছবিটি 500 পিক্সেলের প্রস্থে প্রদর্শিত হবে। ছোট ডিভাইসে, চিত্রটি 100vw অথবা সম্পূর্ণ ভিউপোর্ট প্রস্থে প্রদর্শিত হয়।

ব্রাউজার তারপরে সর্বোত্তম চিত্র খুঁজে পেতে srcset চিত্র উত্সগুলির তালিকার সাথে এই তথ্যগুলিকে একত্রিত করতে পারে। উদাহরণস্বরূপ, যদি ব্যবহারকারী একটি মোবাইল ডিভাইসে থাকে যার স্ক্রীন প্রস্থ 320 পিক্সেলের 3 এর DPR সহ, চিত্রটি 320 CSS pixels x 3 DPR = 960 device pixels প্রদর্শিত হয়। এই উদাহরণে, নিকটতম আকারের চিত্রটি হবে image-1000.jpg যার অন্তর্নিহিত প্রস্থ 1000 পিক্সেল ( 1000w )।

ফাইল ফরম্যাট

ব্রাউজারগুলি বিভিন্ন ইমেজ ফাইল ফরম্যাট সমর্থন করে। WebP এবং AVIF এর মত আধুনিক ইমেজ ফরম্যাট PNG বা JPEG এর চেয়ে ভালো কম্প্রেশন প্রদান করতে পারে, যা আপনার ইমেজ ফাইলের আকারকে ছোট করে এবং তাই ডাউনলোড করতে কম সময় নেয়। আধুনিক বিন্যাসে ছবি পরিবেশন করার মাধ্যমে, আপনি একটি সম্পদের লোডের সময় কমাতে পারেন, যার ফলে একটি নিম্নতর বৃহৎ কন্টেন্টফুল পেইন্ট (LCP) হতে পারে।

WebP একটি ব্যাপকভাবে সমর্থিত ফর্ম্যাট যা সমস্ত আধুনিক ব্রাউজারে কাজ করে। WebP-এর প্রায়শই JPEG, PNG, বা GIF এর চেয়ে ভাল কম্প্রেশন থাকে, যা ক্ষতিকর এবং ক্ষতিহীন উভয় কম্প্রেশন অফার করে। ক্ষতিকর কম্প্রেশন ব্যবহার করার সময়ও WebP আলফা চ্যানেলের স্বচ্ছতাকেও সমর্থন করে—যেটি JPEG কোডেক অফার করে না এমন একটি বৈশিষ্ট্য।

AVIF হল একটি নতুন ইমেজ ফরম্যাট, এবং যদিও এটি WebP এর মত ব্যাপকভাবে সমর্থিত নয়, এটি ব্রাউজার জুড়ে যুক্তিসঙ্গতভাবে শালীন সমর্থন উপভোগ করে। AVIF ক্ষতিকারক এবং ক্ষতিহীন উভয় কম্প্রেশন সমর্থন করে এবং কিছু ক্ষেত্রে JPEG-এর তুলনায় পরীক্ষাগুলি 50%-এর বেশি সঞ্চয় দেখিয়েছে। AVIF ওয়াইড কালার গামুট (WCG) এবং হাই ডায়নামিক রেঞ্জ (HDR) বৈশিষ্ট্যও অফার করে।

কম্প্রেশন

যেখানে চিত্রগুলি উদ্বিগ্ন, সেখানে দুটি ধরণের সংকোচন রয়েছে:

  1. ক্ষতিকর কম্প্রেশন
  2. ক্ষতিহীন কম্প্রেশন

ক্ষতিকারক কম্প্রেশন কোয়ান্টাইজেশনের মাধ্যমে চিত্রের যথার্থতা হ্রাস করে কাজ করে এবং ক্রোমা সাবস্যাম্পলিং ব্যবহার করে অতিরিক্ত রঙের তথ্য বাতিল করা যেতে পারে। ক্ষতিকারক সংকোচন উচ্চ-ঘনত্বের চিত্রগুলিতে প্রচুর শব্দ এবং রঙের ক্ষেত্রে সবচেয়ে কার্যকর—সাধারণত একই বিষয়বস্তু সহ ফটো বা চিত্র। এর কারণ হল ক্ষতিকর কম্প্রেশন দ্বারা উত্পাদিত শিল্পকর্মগুলি এই ধরনের বিস্তারিত চিত্রগুলিতে লক্ষ্য করার সম্ভাবনা অনেক কম। যাইহোক, লাইন আর্ট, একইভাবে স্টার্ক ডিটেইলস বা টেক্সটের মতো তীক্ষ্ণ প্রান্তযুক্ত চিত্রাবলীর সাথে ক্ষতিকর কম্প্রেশন কম কার্যকর হতে পারে। ক্ষতিকর কম্প্রেশন JPEG, WebP, এবং AVIF ছবিতে প্রয়োগ করা যেতে পারে।

লসলেস কম্প্রেশন কোনো ডেটা ক্ষতি ছাড়াই একটি ইমেজ কম্প্রেস করে ফাইলের আকার কমিয়ে দেয়। লসলেস কম্প্রেশন তার প্রতিবেশী পিক্সেল থেকে পার্থক্যের উপর ভিত্তি করে একটি পিক্সেল বর্ণনা করে। GIF, PNG, WebP, এবং AVIF ইমেজ ফরম্যাটের জন্য লসলেস কম্প্রেশন ব্যবহার করা হয়।

আপনি Squosh , ImageOptim , বা একটি ইমেজ অপ্টিমাইজেশান পরিষেবা ব্যবহার করে আপনার ছবিগুলিকে সংকুচিত করতে পারেন৷ কম্প্রেস করার সময়, সব ক্ষেত্রে উপযুক্ত একটি সার্বজনীন সেটিং নেই। যতক্ষণ না আপনি চিত্রের গুণমান এবং ফাইলের আকারের মধ্যে একটি ভাল আপস খুঁজে না পান ততক্ষণ পর্যন্ত প্রস্তাবিত পদ্ধতিটি বিভিন্ন কম্প্রেশন স্তরের সাথে পরীক্ষা করা হবে। কিছু উন্নত ইমেজ অপ্টিমাইজেশান পরিষেবাগুলি স্বয়ংক্রিয়ভাবে আপনার জন্য এটি করতে পারে, তবে সমস্ত ব্যবহারকারীর জন্য আর্থিকভাবে কার্যকর নাও হতে পারে৷

<picture> উপাদান

<picture> উপাদানটি আপনাকে একাধিক ইমেজ প্রার্থী নির্দিষ্ট করার ক্ষেত্রে আরও নমনীয়তা দেয়:

<picture>
  <source type="image/avif" srcset="image.avif">
  <source type="image/webp" srcset="image.webp">
  <img
    alt="An image"
    width="500"
    height="500"
    src="/image.jpg"
  >
</picture>

আপনি যখন <picture> উপাদানের মধ্যে <source> উপাদান(গুলি) ব্যবহার করেন, আপনি AVIF এবং WebP চিত্রগুলির জন্য সমর্থন যোগ করতে পারেন, কিন্তু ব্রাউজারটি আধুনিক বিন্যাস সমর্থন না করলে আরও সামঞ্জস্যপূর্ণ লিগ্যাসি চিত্র বিন্যাসে ফিরে যেতে পারেন। এই পদ্ধতির সাহায্যে, ব্রাউজার প্রথম <source> উপাদানটি বেছে নেয় যা মেলে। যদি এটি সেই বিন্যাসে চিত্রটিকে রেন্ডার করতে পারে তবে এটি সেই চিত্রটি ব্যবহার করে। অন্যথায়, ব্রাউজার পরবর্তী নির্দিষ্ট <source> উপাদানে চলে যায়। পূর্ববর্তী HTML স্নিপেটে, AVIF ফর্ম্যাট WebP ফর্ম্যাটের উপর অগ্রাধিকার নেয়, যদি AVIF বা WebP সমর্থিত না হয় তাহলে JPEG ফর্ম্যাটে ফিরে আসে৷

একটি <picture> উপাদানটির ভিতরে একটি <img> উপাদান প্রয়োজন। alt , width , এবং height বৈশিষ্ট্যগুলি <img> -এ সংজ্ঞায়িত করা হয় এবং যেটি <source> নির্বাচন করা হোক না কেন ব্যবহার করা হয়।

<source> উপাদানটি media , srcset এবং sizes বৈশিষ্ট্যগুলিকেও সমর্থন করে। একইভাবে আগের <img> উদাহরণের মতো, এগুলি ব্রাউজারকে নির্দেশ করে যে বিভিন্ন ভিউপোর্টে কোন ছবি নির্বাচন করতে হবে।

<picture>
  <source
    media="(min-resolution: 1.5x)"
    srcset="/image-1000.jpg 1000w, /image-1500.jpg 1500w"
    sizes="(min-width: 768px) 500px, 100vw"
  >
  <img
    alt="An image"
    width="500"
    height="500"
    src="/image-500.jpg"
  >
</picture>

media বৈশিষ্ট্য একটি মিডিয়া শর্ত লাগে। পূর্ববর্তী উদাহরণে, ডিভাইসের DPR মিডিয়া শর্ত হিসাবে ব্যবহৃত হয়। 1.5 এর চেয়ে বেশি বা সমান DPR সহ যেকোনো ডিভাইস প্রথম <source> উপাদান ব্যবহার করবে। <source> উপাদানটি ব্রাউজারকে বলে যে, 768 পিক্সেলের চেয়ে চওড়া ভিউপোর্ট সহ ডিভাইসগুলিতে, নির্বাচিত চিত্র প্রার্থী 500 পিক্সেল চওড়ায় প্রদর্শিত হয়। ছোট ডিভাইসে, এটি পুরো ভিউপোর্ট প্রস্থ নেয়। media এবং srcset বৈশিষ্ট্যগুলি একত্রিত করে, আপনি কোন চিত্রটি ব্যবহার করবেন তার উপর সূক্ষ্ম নিয়ন্ত্রণ রাখতে পারেন।

এটি নিম্নলিখিত সারণীতে চিত্রিত করা হয়েছে, যেখানে বেশ কয়েকটি ভিউপোর্ট প্রস্থ এবং ডিভাইস পিক্সেল অনুপাত মূল্যায়ন করা হয়েছে:

ভিউপোর্ট প্রস্থ (পিক্সেল) 1 ডিপিআর 1.5 ডিপিআর 2 ডিপিআর 3 ডিপিআর
320 500.jpg 500.jpg 500.jpg 1000.jpg
480 500.jpg 500.jpg 1000.jpg 1500.jpg
560 500.jpg 1000.jpg 1000.jpg 1500.jpg
1024 500.jpg 1000.jpg 1000.jpg 1500.jpg
1920 500.jpg 1000.jpg 1000.jpg 1500.jpg

1 এর ডিপিআর সহ ডিভাইসগুলি image-500.jpg ইমেজ ডাউনলোড করে, যার মধ্যে বেশিরভাগ ডেস্কটপ ব্যবহারকারী-যারা 500 পিক্সেল চওড়া একটি বহিরাগত আকারে ছবিটি দেখেন। অন্যদিকে, 3-এর DPR সহ মোবাইল ব্যবহারকারীরা একটি সম্ভাব্য বড় image-1500.jpg ডাউনলোড করে — একই ছবি 3-এর DPR সহ ডেস্কটপ ডিভাইসে ব্যবহৃত হয়।

<picture>
  <source
    media="(min-width: 561px) and (min-resolution: 1.5x)"
    srcset="/image-1000.jpg 1000w, /image-1500.jpg 1500w"
    sizes="(min-width: 768px) 500px, 100vw"
  >
  <source
    media="(max-width: 560px) and (min-resolution: 1.5x)"
    srcset="/image-1000-sm.jpg 1000w, /image-1500-sm.jpg 1500w"
    sizes="(min-width: 768px) 500px, 100vw"
  >
  <img
    alt="An image"
    width="500"
    height="500"
    src="/image-500.jpg"
  >
</picture>

এই উদাহরণে, উচ্চ ডিপিআর সহ প্রশস্ত ডিভাইসগুলির জন্য বিভিন্ন চিত্র ব্যবহার করার জন্য একটি অতিরিক্ত <source> উপাদান অন্তর্ভুক্ত করার জন্য <picture> উপাদানটি সামঞ্জস্য করা হয়েছে:

ভিউপোর্ট প্রস্থ (পিক্সেল) 1 ডিপিআর 1.5 ডিপিআর 2 ডিপিআর 3 ডিপিআর
320 500.jpg 500.jpg 1000-sm.jpg 1000-sm.jpg
480 500.jpg 500.jpg 1000-sm.jpg 1500-sm.jpg
560 500.jpg 1000-sm.jpg 1000-sm.jpg 1500-sm.jpg
1024 500.jpg 1000.jpg 1000.jpg 1500.jpg
1920 500.jpg 1000.jpg 1000.jpg 1500.jpg

এই অতিরিক্ত ক্যোয়ারীটির মাধ্যমে, আপনি দেখতে পাচ্ছেন যে image-1000-sm.jpg এবং image-1500-sm.jpg ছোট ভিউপোর্টে প্রদর্শিত হচ্ছে। এই অতিরিক্ত তথ্যটি আপনাকে ছবিগুলিকে আরও সংকুচিত করতে দেয়, যেহেতু কম্প্রেশন আর্টিফ্যাক্টগুলি সেই আকার এবং ঘনত্বে খুব বেশি দৃশ্যমান নয়, পাশাপাশি ডেস্কটপ ডিভাইসগুলিতে চিত্রের গুণমানের সাথে আপস করে না।

বিকল্পভাবে, srcset এবং media বৈশিষ্ট্যগুলি সামঞ্জস্য করে, আপনি ছোট ভিউপোর্টে বড় ছবি পরিবেশন করা এড়াতে পারেন:

<picture>
  <source
    media="(min-width: 561px)"
    srcset="/image-500.jpg, /image-1000.jpg 2x, /image-1500.jpg 3x"
  >
  <source
    media="(max-width: 560px)"
    srcset="/image-500.jpg 1x, /image-1000.jpg 2x"
  >
  <img
    alt="An image"
    width="500"
    height="500"
    src="/image-500.jpg"
  >
</picture>

পূর্ববর্তী এইচটিএমএল স্নিপেটে, ডিভাইস পিক্সেল অনুপাত বর্ণনাকারীর পক্ষে প্রস্থ বর্ণনাকারীগুলি সরানো হয়েছে। একটি মোবাইল ডিভাইসে পরিবেশিত ছবিগুলি /image-500.jpg বা /image-1000.jpg এর মধ্যে সীমাবদ্ধ, এমনকি 3 এর DPR সহ ডিভাইসেও৷

কীভাবে জটিলতা পরিচালনা করবেন

প্রতিক্রিয়াশীল চিত্রগুলির সাথে কাজ করার সময়, আপনি প্রতিটি চিত্রের জন্য বিভিন্ন আকারের বৈচিত্র এবং বিন্যাসের সাথে নিজেকে খুঁজে পেতে পারেন। পূর্ববর্তী উদাহরণে, প্রতিটি আকারের বৈচিত্র ব্যবহার করা হয়, তবে AVIF এবং WebP বাদ দিন। আপনার কতগুলি বৈকল্পিক থাকা উচিত? অনেক ইঞ্জিনিয়ারিং সমস্যার মতো, উত্তরটি "এটি নির্ভর করে" হতে থাকে।

সর্বোত্তম ফিট ডেলিভারি করার জন্য অনেকগুলি বৈচিত্র্য থাকা লোভনীয় হতে পারে, প্রতিটি অতিরিক্ত চিত্র বৈকল্পিক একটি খরচে আসে এবং ব্রাউজার ক্যাশের কম দক্ষ ব্যবহার করে। শুধুমাত্র একটি ভেরিয়েন্টের সাথে, প্রতিটি ব্যবহারকারী একই চিত্র গ্রহণ করে, তাই এটি খুব দক্ষতার সাথে ক্যাশে করা যেতে পারে।

অন্য দিকে, যদি অনেক বৈচিত্র্য থাকে, প্রতিটি বৈকল্পিক অন্য ক্যাশে এন্ট্রি প্রয়োজন। সার্ভারের খরচ বাড়তে পারে এবং কার্যক্ষমতা হ্রাস করতে পারে যদি ভেরিয়েন্টের ক্যাশে এন্ট্রির মেয়াদ শেষ হয়ে যায়, এবং ছবিটি আবার অরিজিন সার্ভার থেকে আনতে হবে।

এটি ছাড়াও, আপনার HTML নথির আকার প্রতিটি পরিবর্তনের সাথে বৃদ্ধি পায়। আপনি প্রতিটি ছবির জন্য একাধিক কিলোবাইট এইচটিএমএল শিপিং করতে পারেন।

অনুরোধ Accept শিরোনাম উপর ভিত্তি করে ছবি পরিবেশন

Accept HTTP রিকোয়েস্ট হেডার সার্ভারকে জানায় যে ব্যবহারকারীর ব্রাউজার কোন ধরনের বিষয়বস্তু বুঝতে পারে। এই তথ্যটি আপনার সার্ভার দ্বারা আপনার HTML প্রতিক্রিয়াগুলিতে অতিরিক্ত বাইট যোগ না করে সর্বোত্তম চিত্র বিন্যাস পরিবেশন করতে ব্যবহার করা যেতে পারে।

if (request.headers.accept) {
  if (request.headers.accept.includes('image/avif')) {
    return reply.from('image.avif');
  } else if (request.headers.accept.includes('image/webp')) {
    return reply.from('image.webp');
  }
}

return reply.from('image.jpg');

পূর্ববর্তী HTML স্নিপেট হল কোডের একটি সরলীকৃত সংস্করণ যা আপনি আপনার সার্ভারের JavaScript ব্যাকএন্ডে যোগ করতে পারেন এবং সর্বোত্তম চিত্র বিন্যাসটি চয়ন করতে এবং পরিবেশন করতে পারেন৷ যদি অনুরোধ Accept শিরোনামে image/avif অন্তর্ভুক্ত থাকে, তাহলে AVIF চিত্রটি পরিবেশিত হয়। অন্যথায়, যদি Accept হেডারে image/webp অন্তর্ভুক্ত থাকে, তাহলে WebP ইমেজ পরিবেশিত হয়। যদি এই শর্তগুলির কোনটিই সত্য না হয়, তাহলে JPEG ইমেজ পরিবেশিত হয়।

আপনি প্রায় প্রতিটি ধরণের ওয়েব সার্ভারে Accept অনুরোধ শিরোনামের বিষয়বস্তুর ভিত্তিতে প্রতিক্রিয়াগুলি সংশোধন করতে পারেন - উদাহরণস্বরূপ, আপনি mod_rewrite ব্যবহার করে Accept শিরোনামের উপর ভিত্তি করে অ্যাপাচি সার্ভারগুলিতে চিত্রের অনুরোধগুলি পুনরায় লিখতে পারেন।

এটি কোনও চিত্রের বিষয়বস্তু বিতরণ নেটওয়ার্ক (সিডিএন) এ আপনি যে আচরণের সন্ধান পাবেন তার বিপরীতে নয়। চিত্রের সিডিএনগুলি চিত্রগুলি অনুকূলিতকরণ এবং ব্যবহারকারীর ডিভাইস এবং ব্রাউজারের উপর ভিত্তি করে অনুকূল ফর্ম্যাট প্রেরণের জন্য দুর্দান্ত সমাধান।

মূলটি হ'ল একটি ভারসাম্য সন্ধান করা, যুক্তিসঙ্গত সংখ্যক চিত্র প্রার্থীদের উত্পন্ন করা এবং ব্যবহারকারীর অভিজ্ঞতার উপর প্রভাব পরিমাপ করা। বিভিন্ন চিত্র বিভিন্ন ফলাফল দিতে পারে এবং প্রতিটি চিত্রের জন্য প্রয়োগ করা অপ্টিমাইজেশনগুলি পৃষ্ঠার মধ্যে এর আকারের উপর নির্ভর করে এবং আপনার ব্যবহারকারীরা যে ডিভাইসগুলি ব্যবহার করছেন তা নির্ভর করে। উদাহরণস্বরূপ, একটি পূর্ণ-প্রস্থের নায়ক চিত্রের জন্য ইকমার্স পণ্য তালিকা পৃষ্ঠায় থাম্বনেইল চিত্রগুলির চেয়ে আরও বেশি বৈকল্পিক প্রয়োজন হতে পারে।

অলস লোড হচ্ছে

loading অ্যাট্রিবিউটটি ব্যবহার করে ভিউপোর্টে উপস্থিত হওয়ার সময় ব্রাউজারটিকে অলস লোড চিত্রগুলি বলতে বলা সম্ভব। lazy একটি বৈশিষ্ট্য মান ব্রাউজারকে ভিউপোর্টে (বা কাছাকাছি) না হওয়া পর্যন্ত চিত্রটি ডাউনলোড না করার জন্য বলে। এটি ব্যান্ডউইথ সাশ্রয় করে, ব্রাউজারটিকে ইতিমধ্যে ভিউপোর্টে থাকা সমালোচনামূলক সামগ্রীটি রেন্ডার করার জন্য প্রয়োজনীয় সংস্থানগুলি অগ্রাধিকার দেওয়ার অনুমতি দেয়।

decoding

decoding অ্যাট্রিবিউট ব্রাউজারটিকে কীভাবে চিত্রটি ডিকোড করা উচিত তা জানায়। async একটি মান ব্রাউজারকে বলে যে চিত্রটি অ্যাসিঙ্ক্রোনালিভাবে ডিকোড করা যেতে পারে, সম্ভবত অন্যান্য সামগ্রী রেন্ডার করার জন্য সময়কে উন্নত করে। sync একটি মান ব্রাউজারকে বলে যে চিত্রটি অন্যান্য সামগ্রীর মতো একই সময়ে উপস্থাপন করা উচিত। auto ডিফল্ট মান ব্রাউজারটিকে ব্যবহারকারীর পক্ষে সবচেয়ে ভাল কী তা সিদ্ধান্ত নিতে দেয়।

চিত্র ডেমো

আপনার জ্ঞান পরীক্ষা করুন

কোন চিত্র ফর্ম্যাটগুলি ক্ষতিহীন সংকোচনের সমর্থন করে?

জিআইএফ
সঠিক!
জেপিইজি।
আবার চেষ্টা করুন
পিএনজি।
সঠিক!
ওয়েবপি
সঠিক!
এভিআইএফ।
সঠিক!

কোন চিত্রের ফর্ম্যাটগুলি ক্ষতির সংকোচনের সমর্থন করে?

জিআইএফ
আবার চেষ্টা করুন যদিও জিআইএফ ফর্ম্যাটটি কেবল 256 রঙের একটি সীমিত প্যালেট সমর্থন করে, তবে জিআইএফ -তে রূপান্তর করার আগে ক্ষতিগ্রস্থ এনকোডিং অবশ্যই করা উচিত।
জেপিইজি।
সঠিক!
পিএনজি।
আবার চেষ্টা করুন
ওয়েবপি
সঠিক!
এভিআইএফ।
সঠিক!

প্রস্থ বর্ণনাকারী (উদাহরণস্বরূপ, 1000w ) ব্রাউজারটিকে একটি srcset অ্যাট্রিবিউটে নির্দিষ্ট করা কোনও চিত্র প্রার্থী সম্পর্কে কী বলে?

চিত্রের বহিরাগত প্রস্থ - অর্থা
আবার চেষ্টা করুন
চিত্রের অভ্যন্তরীণ প্রস্থ - এটি হ'ল চিত্রের মাত্রা।
সঠিক!

sizes বৈশিষ্ট্যগুলি ব্রাউজারটিকে কী <img> উপাদানটি প্রয়োগ করা হয়েছে সে সম্পর্কে কী বলে?

ব্যবহারকারীর বর্তমান ভিউপোর্টের মাত্রাগুলি বিবেচনা করে কোনও <img> এলিমেন্টের srcset -তে নির্দিষ্ট প্রার্থী নির্দিষ্ট করা কোন প্রার্থীকে প্রকাশ করে তা যুক্তিযুক্ত যুক্তিযুক্ত।
সঠিক!
The intrinsic width of the image to be loaded from the <img> element's srcset attribute.
আবার চেষ্টা করুন

পরবর্তী পরবর্তী: ভিডিও পারফরম্যান্স

যদিও চিত্রগুলি ওয়েবে ব্যবহৃত সর্বাধিক প্রচলিত মিডিয়া টাইপ হতে পারে তবে পারফরম্যান্সের ক্ষেত্রে আপনার মনে রাখা দরকার কেবলমাত্র এগুলি থেকে দূরে। ভিডিওটি ওয়েব জুড়ে ব্যবহৃত অন্য সাধারণ ধরণের মিডিয়া এবং এটি নিজস্ব পারফরম্যান্স বিবেচনার সাথে আসে। এই কোর্সের পরবর্তী মডিউলে , ভিডিওগুলি অনুকূলিতকরণ এবং কীভাবে সেগুলি দক্ষতার সাথে লোড করবেন সে সম্পর্কে কিছু কৌশল অন্বেষণ করুন।