Sprockets Rails กับฟ้อนต์ที่ไม่โหลด
- rails
- sprockets
- LFP
หลังจากที่โปรเจ็คหลายๆ ตัวได้อัพเวอร์ชันมาใช้ Rails 7 อีกสิ่งหนึ่งที่ได้รับผลกระทบตามมาคือการจัดการ asset ต่างๆ ที่อยู่ภายใน ซึ่งใน Rails 7 เปิดทางเลือกให้ผู้พัฒนาเลือกใช้เครื่องมือในการจัดการ JavaScript และ CSS ใดๆ ก็ได้ที่ถนัด
สำหรับเราเอง เราเลือกใช้ gem sprockets
มาแต่ไหนแต่ไร เพียงแต่ในเวอร์ชัน 7 เราจะต้องอัพเดตการใช้งานจาก sprockets
มาเป็น sprockets-rails
เพียงแต่สิ่งที่เราเจอคือฟ้อนต์ต่างๆ ที่เราอ้างอิงไว้ในไฟล์ CSS ไม่ถูกโหลดเมื่อนำไปใช้งานจริง (Production)
ถ้าย้อนกลับไปที่การอ้างอิง asset ต่างๆ ใน CSS ตอนที่เรายังใช้ sprockets
จะมี helper ให้ใช้งานอยู่ไม่ว่าจะเป็น asset-path|asset-url
, image-path|image-url
, font-path|font-url
โดยการอ้างอิงฟ้อนต์ที่เราใช้อยู่จะเป็นดังตัวอย่างด้านล่าง
@font-face {
...
src: font-url("IBMPlexSansThai-Regular.woff2") format("woff2");
}
จะเห็นได้ว่าเราเรียกใช้ helper font-url
ในการอ้างอิง URL เมื่อถูก compile ด้วยคำสั่ง rails assets:precompile
จะถูกแปลงเป็น
@font-face {
...
src: url("/assets/IBMPlexSansThai-Regular-8cb267db96213347f522e3bc8a04822009fd83e45718c40f933a5aeb33d22446.woff2") format("woff2");
}
แต่เมื่อเปลี่ยนมาใช้ sprockets-rails
ปรากฏว่าเมื่อสั่ง compile จะได้ออกมาเหมือนเดิม ซึ่ง font-url
ไม่ใช้ syntax ที่ CSS รู้จัก จึงทำให้ฟ้อนต์ไม่ถูกโหลดมาใช้งาน
จากที่ได้เข้าไปดูในโค้ด ปรากฏว่าจริงๆ แล้วเราไม่จำเป็นต้องใช้ helper อีกต่อไป เพราะตัว processor ใหม่จะตรวจจับจาก url()
ที่อยู่ใน CSS และจัดการใส่ URL ที่ถูกต้องเข้าไป
AssetUrlProcessor
ดังนั้นต่อไปนี้ถ้าเราจะอ้างถึง asset ใดๆ ที่อยู่ใน CSS
ก็ให้เรียกผ่าน url()
ได้เลย ดังตัวอย่างด้านล่าง
@font-face {
...
src: url("IBMPlexSansThai-Regular.woff2") format("woff2");
}