เราทุกคนเคยเจอปัญหานี้มาแล้ว นั่นคือคุณลืมปรับขนาดรูปภาพให้เล็กลงก่อนที่จะเพิ่มลงในหน้าเว็บ รูปภาพดูดี แต่ใช้ข้อมูลของผู้ใช้อย่างสิ้นเปลืองและส่งผลเสียต่อประสิทธิภาพของหน้าเว็บ
ระบุรูปภาพที่มีขนาดไม่ถูกต้อง
Lighthouse ช่วยให้ระบุรูปภาพที่มีขนาดไม่ถูกต้องได้อย่างง่ายดาย เรียกใช้การตรวจสอบประสิทธิภาพ (Lighthouse > ตัวเลือก > ประสิทธิภาพ) แล้วดูผลการตรวจสอบปรับขนาดรูปภาพให้เหมาะสม การตรวจสอบจะแสดงรูปภาพที่ต้องปรับขนาด
ระบุขนาดรูปภาพที่ถูกต้อง
การปรับขนาดรูปภาพอาจดูซับซ้อนกว่าที่เป็น ด้วยเหตุนี้ เราจึงมีแนวทาง 2 วิธี ได้แก่ "ดี" และ "ดีกว่า" ทั้ง 2 อย่างจะช่วยปรับปรุงประสิทธิภาพ แต่แนวทางที่ "ดีกว่า" อาจใช้เวลาในการทำความเข้าใจและ นำไปใช้นานกว่าเล็กน้อย แต่ก็จะให้รางวัลคุณด้วยการปรับปรุงประสิทธิภาพที่มากขึ้นด้วย ตัวเลือกที่ดีที่สุดสำหรับคุณคือตัวเลือกที่คุณใช้งานได้อย่างสะดวกสบาย
หมายเหตุสั้นๆ เกี่ยวกับหน่วย CSS
หน่วย CSS สำหรับระบุขนาดขององค์ประกอบ HTML ซึ่งรวมถึงรูปภาพมีอยู่ 2 ประเภท ได้แก่
- หน่วยสัมบูรณ์: องค์ประกอบที่กำหนดรูปแบบโดยใช้หน่วยสัมบูรณ์จะแสดงในขนาดเดียวกันเสมอ โดยไม่คำนึงถึงอุปกรณ์ ตัวอย่างหน่วย CSS แบบสัมบูรณ์ที่ถูกต้อง ได้แก่ px, cm, mm, in
- หน่วยแบบสัมพัทธ์: องค์ประกอบที่มีการจัดสไตล์โดยใช้หน่วยแบบสัมพัทธ์จะแสดงในขนาดที่ต่างกัน โดยขึ้นอยู่กับความยาวแบบสัมพัทธ์ที่ระบุ ตัวอย่างหน่วย CSS แบบสัมพัทธ์ที่ถูกต้อง ได้แก่ %, vw (1vw = 1% ของความกว้างของวิวพอร์ต), em (1.5 em = 1.5 เท่าของขนาดแบบอักษร)
แนวทาง "ดี"
สำหรับรูปภาพที่มีการปรับขนาดตาม…
- หน่วยสัมพัทธ์: ปรับขนาดรูปภาพเป็นขนาดที่ใช้ได้กับอุปกรณ์ทั้งหมด
คุณอาจพบว่าการตรวจสอบข้อมูลวิเคราะห์ (เช่น Google Analytics) เพื่อดูว่าผู้ใช้ใช้ขนาดการแสดงผลใดกันบ้างนั้นมีประโยชน์ หรือจะใช้ screensiz.es ที่แสดงข้อมูลเกี่ยวกับจอแสดงผลของอุปกรณ์ทั่วไปหลายรุ่นก็ได้ - หน่วยสัมบูรณ์: ปรับขนาดรูปภาพให้ตรงกับขนาดที่ปรากฏ
คุณใช้แผงองค์ประกอบของ DevTools เพื่อดูขนาดที่รูปภาพแสดงได้
แนวทาง "ดีกว่า"
สำหรับรูปภาพที่มีทั้งขนาดสัมบูรณ์และสัมพัทธ์ ให้ใช้แอตทริบิวต์ srcset
และ sizes
เพื่อแสดงรูปภาพที่แตกต่างกันตามความหนาแน่นของการแสดงผล
อ่านคู่มือเกี่ยวกับรูปภาพที่ปรับเปลี่ยนตามอุปกรณ์
"ความหนาแน่นของจอแสดงผล" หมายถึงจอแสดงผลแต่ละประเภทมีความหนาแน่นของพิกเซลแตกต่างกัน เมื่อปัจจัยอื่นๆ เท่ากัน จอแสดงผลที่มีความหนาแน่นของพิกเซลสูงจะดูคมชัดกว่าจอแสดงผลที่มีความหนาแน่นของพิกเซลต่ำ
คุณจึงต้องใช้รูปภาพหลายเวอร์ชันหากต้องการให้ผู้ใช้ได้รับประสบการณ์การใช้งานรูปภาพที่คมชัดที่สุดเท่าที่จะเป็นไปได้ ไม่ว่าอุปกรณ์ของผู้ใช้จะมีความละเอียดของพิกเซลเท่าใดก็ตาม
เทคนิครูปภาพที่ตอบสนองตามอุปกรณ์ทำให้การดำเนินการนี้เป็นไปได้โดยให้คุณแสดงเวอร์ชันรูปภาพที่หลากหลาย และเพื่อให้อุปกรณ์เลือกรูปภาพที่เหมาะกับตนเองที่สุด
รูปภาพที่ใช้ได้กับทุกอุปกรณ์จะมีขนาดใหญ่เกินความจำเป็นสำหรับอุปกรณ์ขนาดเล็ก เทคนิครูปภาพที่ตอบสนองตามอุปกรณ์ โดยเฉพาะ srcset และขนาด ช่วยให้คุณระบุรูปภาพได้หลายเวอร์ชัน และเพื่อให้อุปกรณ์เลือกขนาดที่เหมาะสมที่สุดได้
ปรับขนาดรูปภาพ
ไม่ว่าคุณจะเลือกวิธีใด คุณอาจพบว่าการใช้ ImageMagick เพื่อปรับขนาดรูปภาพมีประโยชน์ ImageMagick เป็นเครื่องมือบรรทัดคำสั่งยอดนิยมในการสร้างและแก้ไขรูปภาพ ผู้ใช้ส่วนใหญ่ปรับขนาดรูปภาพได้เร็วกว่ามากเมื่อใช้ CLI มากกว่าเครื่องมือแก้ไขรูปภาพแบบ GUI
ปรับขนาดรูปภาพให้เท่ากับขนาดต้นฉบับ 25%
convert flower.jpg -resize 25% flower_small.jpg
ปรับขนาดรูปภาพให้พอดีกับ "กว้าง 200 พิกเซล สูง 100 พิกเซล":
# macOS/Linux
convert flower.jpg -resize 200x100 flower_small.jpg
# Windows
magick convert flower.jpg -resize 200x100 flower_small.jpg
หากคุณจะปรับขนาดรูปภาพจำนวนมาก การใช้สคริปต์หรือบริการเพื่อดำเนินการแบบอัตโนมัติอาจสะดวกกว่า ดูข้อมูลเพิ่มเติมได้ในคำแนะนำเกี่ยวกับรูปภาพที่ปรับเปลี่ยนขนาดได้
หลีกเลี่ยงการเลื่อนเลย์เอาต์โดยระบุขนาด
แม้ว่าคู่มือนี้จะกล่าวถึงขนาดของรูปภาพในบริบทของการลดจำนวนไบต์ที่ไม่จำเป็นที่ดาวน์โหลด แต่สิ่งสำคัญที่ควรทราบคือ การสำรองพื้นที่ที่ถูกต้องสำหรับรูปภาพในการจัดวางเป็นอีกองค์ประกอบสำคัญในการลดเมตริก Cumulative Layout Shift ของหน้าเว็บ เมื่อแสดงรูปภาพใน HTML ให้ใช้แอตทริบิวต์ width
และ height
ที่เหมาะสมเพื่อให้เบราว์เซอร์ทราบปริมาณพื้นที่ที่จะจัดสรรในเลย์เอาต์สำหรับรูปภาพ
<img src="flower.jpg" width="640" height="480" alt="A picture of a siberian iris.">
หากไม่มีแอตทริบิวต์เหล่านี้หรือการกำหนดขนาด CSS ที่เทียบเท่า เบราว์เซอร์จะไม่ทราบพื้นที่ที่รูปภาพจะกินไปจนกว่าจะโหลด ซึ่งจะทำให้เลย์เอาต์ในเอกสารเปลี่ยนไป ซึ่งอาจทำให้ผู้ใช้ไม่พอใจเมื่อเนื้อหาย้ายไปหลังจากที่ผู้ใช้เริ่มดูแล้ว ซึ่งอาจส่งผลให้ผู้ใช้อ่านไม่เจอตำแหน่งเดิมเมื่ออ่านต่อ หรือ "พลาด" เป้าหมายการคลิกที่ต้องการ และสุดท้ายคลิกไปที่สิ่งอื่นที่ไม่ได้ตั้งใจในระหว่างการโหลดหน้าเว็บ
อีกทางเลือกหนึ่งในการระบุความกว้างและความสูงอย่างชัดเจนคือการใช้พร็อพเพอร์ตี้ aspect-ratio
ของ CSS ในรูปภาพ ซึ่งจะมีผลต่อขนาดขององค์ประกอบคล้ายกับแอตทริบิวต์ width
และ height
ในแง่ที่ว่าคอนเทนเนอร์จะรักษาสัดส่วนการแสดงผลที่สอดคล้องกัน แต่ความแตกต่างคือวิธีนี้อาจทำให้มีการใช้สัดส่วนภาพที่แตกต่างจากรูปภาพที่ให้ไว้ คุณจึงอาจต้องใช้การตั้งค่า object-fit
เพื่อให้แน่ใจว่ารูปภาพจะไม่บิดเบี้ยวในมุมมอง 16/9 ที่ชัดเจนนี้
img {
aspect-ratio: 16 / 9;
width: 100%;
object-fit: cover;
}
ยืนยัน
เมื่อปรับขนาดรูปภาพทั้งหมดแล้ว ให้เรียกใช้ Lighthouse อีกครั้งเพื่อตรวจสอบว่าคุณไม่ได้พลาดอะไรไป