object-fit: cover
จะทำสิ่งที่คุณต้องการ
แต่มันอาจไม่ทำงานบน IE / Edge ติดตามที่แสดงด้านล่างที่จะแก้ไขได้ด้วยเพียง CSSในการทำงานในทุกเบราว์เซอร์
วิธีที่ฉันใช้คือจัดตำแหน่งภาพภายในคอนเทนเนอร์ด้วย สัมบูรณ์แล้ววางลงที่กึ่งกลางโดยใช้ชุดค่าผสม:
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
เมื่ออยู่ตรงกลางฉันจะให้ภาพนั้น
// For vertical blocks (i.e., where height is greater than width)
height: 100%;
width: auto;
// For Horizontal blocks (i.e., where width is greater than height)
height: auto;
width: 100%;
สิ่งนี้ทำให้ภาพได้รับผลกระทบจาก Object-fit: cover
นี่คือการสาธิตของตรรกะข้างต้น
https://jsfiddle.net/furqan_694/s3xLe1gp/
ตรรกะนี้ใช้ได้กับทุกเบราว์เซอร์
รูปภาพต้นฉบับ
data:image/s3,"s3://crabby-images/69fdb/69fdb2c8399dfef98a03555af3eded27860d156f" alt="รูปภาพต้นฉบับ"
ตัดแนวตั้ง
data:image/s3,"s3://crabby-images/0d5fb/0d5fbe56c8fb46fa3877414d839368a2d9da3820" alt="ภาพที่ถูกครอบตัดในแนวตั้ง"
ครอบตัดแนวนอน
data:image/s3,"s3://crabby-images/c80aa/c80aa717014128a8e1edd917e26f25f3430f21da" alt="รูปภาพที่ครอบตัดตามแนวนอน"