ทำ PWA ให้เหมือนเป็นแอป

ทำให้ Progressive Web App ดูไม่เหมือนเว็บไซต์ แต่เหมือนแอป "จริง"

เมื่อเล่นบิงโกคำปากต่อปากของ Progressive Web App การตั้งค่าว่า "PWA เป็นเพียงแค่เว็บไซต์" ก็มีความปลอดภัย เอกสาร PWA ของ Microsoft ข้อตกลง เราระบุไว้ในเว็บไซต์นี้ และแม้แต่ Frances Berriman ผู้ได้รับการเสนอชื่อเข้าชิง PWA และ Alex Russell เขียนไว้ด้วยเช่นกัน ใช่แล้ว PWA เป็นแค่เว็บไซต์ แต่ยังมีมากกว่านั้นด้วย หากดำเนินการอย่างถูกต้อง PWA จะไม่ให้ความรู้สึกเหมือนเว็บไซต์ แต่เหมือนแอป "จริง" การให้ความรู้สึกเหมือนแอปจริงหมายความว่าอย่างไร

ในการตอบคำถามนี้ เราขออนุญาตใช้แอป Podcasts ของ Apple เป็นตัวอย่าง ซึ่งพร้อมให้ใช้งานใน macOS บนเดสก์ท็อปและ iOS (และ iPadOS ตามลำดับ) บนอุปกรณ์เคลื่อนที่ แม้ว่า Podcasts จะเป็นแอปพลิเคชันสื่อ แต่แนวคิดหลักที่ผมอธิบายพร้อมช่วยเหลือก็นำมาใช้กับแอปในหมวดหมู่อื่นๆ เช่นกัน

iPhone และ MacBook วางเคียงข้างกัน กำลังเรียกใช้แอปพลิเคชัน Podcasts
Apple Podcasts ใน iPhone และ macOS (แหล่งที่มา)

ทำงานแบบออฟไลน์ได้

หากมองย้อนกลับไปและนึกถึงแอปพลิเคชันเฉพาะแพลตฟอร์มที่คุณใช้ในโทรศัพท์มือถือหรือคอมพิวเตอร์เดสก์ท็อป สิ่งหนึ่งที่เห็นได้ชัดคือคุณจะไม่มีทางได้อะไรเลย แม้ว่าฉันจะออฟไลน์อยู่ แต่ฉันก็ยังมีอะไรใหม่ๆ อยู่ในแอป Podcasts เสมอ เมื่อไม่มีการเชื่อมต่อเครือข่าย แอปจะยังคงเปิดขึ้นตามปกติ ส่วนอันดับสูงสุดจะไม่แสดงเนื้อหาใดๆ แต่จะแสดงข้อความเชื่อมต่อไม่ได้ในขณะนี้ที่จับคู่กับปุ่มลองใหม่แทน อาจไม่ใช่ประสบการณ์ที่ไม่น่าพอใจที่สุด แต่ฉันก็มีอะไรบางอย่างอยู่

แอป Podcasts แสดงข้อความข้อมูล "เชื่อมต่อไม่ได้ในขณะนี้" เมื่อไม่ได้เชื่อมต่อเครือข่าย
แอปพอดแคสต์ที่ไม่มีการเชื่อมต่อเครือข่าย

แอป Podcasts ใช้รูปแบบที่เรียกกันว่า App Shell เนื้อหาแบบคงที่ทั้งหมดที่จำเป็นต่อการแสดงแอปหลักจะได้รับการแคชไว้ในเครื่อง รวมถึงรูปภาพตกแต่ง เช่น ไอคอนเมนูด้านซ้ายมือและไอคอน UI หลักของโปรแกรมเล่น เนื้อหาแบบไดนามิก เช่น ข้อมูลอันดับสูงสุดจะโหลดตามคำขอเท่านั้น และมีเนื้อหาสำรองที่แคชไว้ในเครื่องในกรณีที่โหลดไม่สำเร็จ อ่านบทความโมเดล App Shell เพื่อดูวิธีนำโมเดลสถาปัตยกรรมนี้ไปใช้กับเว็บแอป

มีเนื้อหาออฟไลน์และเล่นสื่อได้

เมื่อออฟไลน์ผ่านลิ้นชักซ้ายมือ ฉันจะยังคงไปที่ส่วนดาวน์โหลดแล้วเพื่อเพลิดเพลินกับตอนของพอดแคสต์ที่ดาวน์โหลดไว้ให้เล่นได้ และจะแสดงพร้อมข้อมูลเมตาทั้งหมด เช่น อาร์ตเวิร์กและคำอธิบาย

แอป Podcasts ที่มีตอนที่ดาวน์โหลดไว้ของพอดแคสต์กำลังเล่น
ตอนของพอดแคสต์ที่ดาวน์โหลดไว้จะเล่นได้แม้ไม่มีเครือข่าย

เนื้อหาสื่อที่ดาวน์โหลดไว้ก่อนหน้านี้สามารถแสดงจากแคช เช่น ใช้สูตรอาหารแสดงเสียงและวิดีโอที่แคชไว้จากคลังกล่องงาน คุณเก็บเนื้อหาอื่นๆ ไว้ในแคชหรือใน IndexedDB ได้ทุกเมื่อ อ่านบทความพื้นที่เก็บข้อมูลสำหรับเว็บเพื่อดูรายละเอียดทั้งหมดและเพื่อให้ทราบว่าควรใช้เทคโนโลยีพื้นที่เก็บข้อมูลแบบใด หากมีข้อมูลที่ควรเก็บไว้ถาวรโดยไม่เสี่ยงต่อการถูกลบถาวรเมื่อหน่วยความจำที่ใช้ได้เหลือน้อย คุณอาจใช้ Persistent Storage API

การดาวน์โหลดในเบื้องหลังเชิงรุก

เมื่อกลับมาออนไลน์ ฉันจะค้นหาเนื้อหาได้ด้วยคำค้นหาอย่างเช่น http 203 และเมื่อฉันตัดสินใจสมัครรับข้อมูลผลการค้นหาพอดแคสต์ HTTP 203 ระบบจะดาวน์โหลดตอนล่าสุดของซีรีส์ทันทีโดยไม่ต้องถามคำถามใดๆ

แอป Podcasts จะดาวน์โหลดตอนล่าสุดของพอดแคสต์ทันทีหลังจากสมัครใช้บริการ
หลังจากสมัครใช้บริการพอดแคสต์ ระบบจะดาวน์โหลดตอนล่าสุดทันที

การดาวน์โหลดตอนของพอดแคสต์เป็นการดำเนินการที่อาจใช้เวลานานกว่านั้น Background Fetch API จะช่วยให้คุณสามารถมอบสิทธิ์การดาวน์โหลดไปยังเบราว์เซอร์ ซึ่งจะดูแลการดาวน์โหลดในเบื้องหลัง สำหรับ Android เบราว์เซอร์ยังสามารถมอบสิทธิ์การดาวน์โหลดเหล่านี้ไปยังระบบปฏิบัติการเพิ่มเติมได้อีกด้วย ดังนั้น เบราว์เซอร์จึงไม่จำเป็นต้องทำงานอย่างต่อเนื่อง เมื่อดาวน์โหลดเสร็จเรียบร้อยแล้ว โปรแกรมทำงานของบริการของแอป (Service Worker) จะปลุกระบบและคุณเลือกได้ว่าจะดำเนินการอย่างไรกับการตอบกลับดังกล่าว

แชร์ไปยังและโต้ตอบกับแอปพลิเคชันอื่น

แอป Podcasts ทำงานร่วมกับแอปพลิเคชันอื่นๆ ได้อย่างเป็นธรรมชาติ เช่น เมื่อคลิกขวาที่ตอนที่ชอบ ผมสามารถแชร์ตอนนั้นกับแอปอื่นๆ ในอุปกรณ์ได้ เช่น แอป Messages นอกจากนี้ยังผสานรวมกับคลิปบอร์ดของระบบได้อย่างเป็นธรรมชาติอีกด้วย ผมสามารถคลิกขวาที่ตอนใดก็ได้ แล้วคัดลอกลิงก์ของตอนนั้น

มีการเรียกใช้เมนูตามบริบทของแอป Podcasts ในตอนของพอดแคสต์โดยเลือกตัวเลือก "แชร์ตอน → ข้อความ"
การแชร์ตอนของพอดแคสต์ไปยังแอป Messages

Web Share API และ Web Share Target API ช่วยให้แอปแชร์และรับข้อความ ไฟล์ รวมถึงลิงก์ไปยังและจากแอปพลิเคชันอื่นๆ ในอุปกรณ์ได้ แม้ว่าเว็บแอปจะเพิ่มรายการเมนูลงในเมนูคลิกขวาในตัวของระบบปฏิบัติการไม่ได้ แต่ก็ยังมีวิธีอื่นๆ อีกมากมายที่สามารถลิงก์เข้าและออกจากแอปอื่นๆ ในอุปกรณ์ได้ Async Clipboard API ช่วยให้คุณอ่านและเขียนข้อมูลข้อความและรูปภาพ (รูปภาพ PNG) ไปยังคลิปบอร์ดของระบบได้โดยใช้โปรแกรม ใน Android คุณสามารถใช้ Contact Picker API เพื่อเลือกรายการจากโปรแกรมจัดการรายชื่อติดต่อของอุปกรณ์ หากให้บริการทั้งแอปเฉพาะแพลตฟอร์มและ PWA ให้ใช้ รับการติดตั้ง API แอปที่เกี่ยวข้อง เพื่อตรวจสอบว่าติดตั้งแอปเฉพาะแพลตฟอร์มหรือไม่ ซึ่งในกรณีนี้คุณไม่จำเป็นต้องกระตุ้นให้ผู้ใช้ติดตั้ง PWA หรือยอมรับข้อความ Push บนเว็บ

การรีเฟรชแอปในเบื้องหลัง

ในการตั้งค่าของแอป Podcasts ฉันกำหนดค่าแอปให้ดาวน์โหลดตอนใหม่ๆ โดยอัตโนมัติได้ แบบนั้นฉันก็ไม่ต้องคิดอะไรเลย เนื้อหาใหม่ๆ ก็จะยังคงอยู่ เวทมนตร์

เมนูการตั้งค่าของแอป Podcasts ในส่วน "ทั่วไป" ซึ่งตั้งค่าตัวเลือก "รีเฟรชพอดแคสต์" เป็น "ทุกชั่วโมง"
พอดแคสต์ที่กำหนดค่าไว้เพื่อตรวจหาตอนใหม่ของพอดแคสต์ทุกชั่วโมง

Periodic Background Sync API ช่วยให้แอปรีเฟรชเนื้อหาเป็นประจำในเบื้องหลังโดยที่ไม่จำเป็นต้องเรียกใช้ ซึ่งหมายความว่าจะมีเนื้อหาใหม่พร้อมใช้งาน เพื่อให้ผู้ใช้เริ่มดูข้อมูลได้ทันทีเมื่อใดก็ตามที่ต้องการ

สถานะที่ซิงค์ผ่านระบบคลาวด์

และพร้อมกัน การสมัครใช้บริการของฉันจะซิงค์กับอุปกรณ์ทุกเครื่องที่ฉันเป็นเจ้าของ ในโลกที่ราบรื่น ฉันไม่ต้องกังวลกับการซิงค์การติดตามพอดแคสต์ด้วยตนเอง เช่นเดียวกัน ฉันไม่ต้องกลัวว่าตอนที่ฉันฟังไปแล้วบนเดสก์ท็อปจะใช้หน่วยความจำของอุปกรณ์เคลื่อนที่ไป สถานะการเล่นจะซิงค์กันและจะลบตอนที่ฟังโดยอัตโนมัติ

เมนูการตั้งค่าของแอป Podcasts ในส่วน "ขั้นสูง" ที่เปิดใช้งานตัวเลือก "ซิงค์การสมัครใช้บริการในอุปกรณ์ต่างๆ"
ระบบซิงค์สถานะผ่านระบบคลาวด์

การซิงค์ข้อมูลสถานะแอปเป็นงานที่คุณมอบสิทธิ์ให้กับ Background Sync API ได้ การดำเนินการซิงค์ไม่จำเป็นต้องเกิดขึ้นทันที เพียงแค่ในที่สุดหรือแม้กระทั่งเมื่อผู้ใช้ปิดแอปอีกครั้งแล้ว

การควบคุมคีย์สื่อด้วยฮาร์ดแวร์

เวลาที่ฉันวุ่นกับแอปพลิเคชันอื่น เช่น อ่านหน้าข่าวในเบราว์เซอร์ Chrome ฉันก็ยังคงควบคุมแอป Podcasts ด้วยคีย์สื่อในแล็ปท็อปได้ ไม่จำเป็นต้องสลับไปที่แอป เพื่อข้ามไปข้างหน้าหรือข้างหลัง

Apple MacBook Pro Magic Keyboard พร้อมปุ่มสื่อที่มีคำอธิบายประกอบ
คีย์สื่อใช้สำหรับควบคุมแอป Podcasts (แหล่งที่มา)

คีย์สื่อได้รับการสนับสนุนโดย Media Session API วิธีนี้ช่วยให้ผู้ใช้ใช้คีย์สื่อฮาร์ดแวร์บนแป้นพิมพ์จริง หูฟัง หรือแม้กระทั่งควบคุมเว็บแอปจากคีย์สื่อซอฟต์แวร์บนสมาร์ทวอทช์ได้ แนวคิดเพิ่มเติมเพื่อให้การดำเนินการกรอวิดีโอเป็นไปอย่างราบรื่นคือการส่งรูปแบบการสั่นเมื่อผู้ใช้สำรวจเนื้อหาส่วนสำคัญ เช่น การส่งเครดิตเริ่มต้นหรือขอบเขตของบท

การทํางานหลายอย่างพร้อมกันและทางลัดของแอป

แน่นอนว่าผมทำงานหลายอย่างกลับไปใช้งานแอป Podcasts ได้จากทุกที่ แอปมีไอคอนที่เห็นได้ชัดเจนซึ่งผมสามารถวางไว้บนเดสก์ท็อปหรือแท่นชาร์จในแอปพลิเคชันได้ด้วย ระบบจึงเปิด Podcasts ได้ทันทีเมื่อต้องการ

เครื่องมือสลับงานของ macOS ที่มีไอคอนแอปมากมายให้เลือก โดยหนึ่งในนั้นคือแอป Podcasts
กลับไปที่แอป Podcasts หลายรายการพร้อมกัน

Progressive Web App ทั้งบนเดสก์ท็อปและอุปกรณ์เคลื่อนที่สามารถติดตั้งลงในหน้าจอหลัก เมนูเริ่มต้น หรือแถบแอปพลิเคชันได้ การติดตั้งอาจเกิดขึ้นตามข้อความแจ้งเชิงรุก หรือควบคุมโดยนักพัฒนาแอปอย่างเต็มรูปแบบ บทความต้องทำอะไรบ้างเพื่อให้ติดตั้งได้ครอบคลุมทุกสิ่งที่คุณจำเป็นต้องทราบ เมื่อทํางานหลายอย่างพร้อมกัน PWA จะปรากฏขึ้นโดยแยกจากเบราว์เซอร์

การดำเนินการด่วนในเมนูตามบริบท

การดำเนินการของแอปที่พบบ่อยที่สุด เช่น การค้นหาเนื้อหาใหม่ และตรวจหาตอนใหม่จะพร้อมใช้งานจากเมนูตามบริบทของแอปใน Dock ฉันสามารถตัดสินใจเปิดแอปเมื่อเข้าสู่ระบบผ่านเมนูตัวเลือกได้ด้วย

เมนูตามบริบทของไอคอนแอป Podcasts ที่แสดงตัวเลือก "ค้นหา" และ "ตรวจหาตอนใหม่"
การใช้งานแบบลัดจะพร้อมใช้งานทันทีจากไอคอนแอป

เมื่อระบุทางลัดไอคอนแอปในไฟล์ Manifest ของเว็บแอปของ PWA คุณจะลงทะเบียนเส้นทางด่วนไปยังงานทั่วไปที่ผู้ใช้เข้าถึงได้โดยตรงจากไอคอนแอป ในระบบปฏิบัติการอย่าง macOS ผู้ใช้คลิกขวาที่ไอคอนแอปและตั้งค่าให้แอปเปิดขึ้นเมื่อเข้าสู่ระบบได้ด้วย เรากำลังดำเนินการกับข้อเสนอสำหรับเรียกใช้เมื่อเข้าสู่ระบบ

ทำหน้าที่เป็นแอปเริ่มต้น

แอปพลิเคชันอื่นๆ ของ iOS และแม้กระทั่งเว็บไซต์หรืออีเมลสามารถผสานรวมกับแอป Podcasts ได้โดยใช้ประโยชน์จากรูปแบบ URL ของ podcasts:// หากติดตามลิงก์อย่างเช่น podcasts://podcasts.apple.com/podcast/the-css-podcast/id1042283903 ขณะอยู่ในเบราว์เซอร์ ระบบจะนำฉันไปยังแอป Podcasts ทันทีและสามารถเลือกว่าจะติดตามหรือฟังพอดแคสต์นั้นได้

เบราว์เซอร์ Chrome แสดงกล่องโต้ตอบการยืนยันที่ถามผู้ใช้ว่าต้องการเปิดแอป Podcasts หรือไม่
คุณเปิดแอป Podcasts จากเบราว์เซอร์ได้โดยตรง

คุณยังจัดการสคีม URL ที่กำหนดเองอย่างเต็มรูปแบบไม่ได้ แต่ข้อเสนอการจัดการโปรโตคอล URL สำหรับ PWA ยังอยู่ระหว่างดำเนินการ ปัจจุบัน registerProtocolHandler() ที่มีคำนำหน้ารูปแบบ web+ คือทางเลือกที่ดีที่สุด

การผสานรวมระบบไฟล์ในเครื่อง

คุณอาจคิดไม่ออกในทันที แต่แอป Podcasts ผสานรวมกับระบบไฟล์ในเครื่องอยู่แล้ว เมื่อฉันดาวน์โหลดตอนของพอดแคสต์ ระบบจะจัดเก็บไฟล์ไว้ใน ~/Library/Group Containers/243LU875E5.groups.com.apple.podcasts/Library/Cache ในแล็ปท็อป ไม่เหมือนกับ ~/Documents แน่นอนว่าไดเรกทอรีนี้ไม่ได้มีจุดประสงค์ให้ผู้ใช้ทั่วไปเข้าถึงโดยตรง แต่เป็นไดเรกทอรี กลไกการเก็บข้อมูลอื่นๆ นอกเหนือจากการอ้างอิงไฟล์จะอยู่ในส่วนเนื้อหาออฟไลน์

เครื่องมือค้นหา macOS ไปยังไดเรกทอรีระบบของแอป Podcasts
ตอนของพอดแคสต์จะอยู่ในโฟลเดอร์แอประบบพิเศษ

File System Access API ช่วยให้นักพัฒนาซอฟต์แวร์มีสิทธิ์เข้าถึงระบบไฟล์ในเครื่องของอุปกรณ์ คุณจะใช้เครื่องมือดังกล่าวโดยตรงหรือผ่านไลบรารีที่รองรับ browser-fs-access ก็ได้ที่มีชุดสำรองสำหรับเบราว์เซอร์ที่ไม่รองรับ API แบบโปร่งใส ไดเรกทอรีของระบบไม่สามารถเข้าถึงเว็บได้เนื่องจากเหตุผลด้านความปลอดภัย

รูปลักษณ์ของแพลตฟอร์ม

สำหรับแอปพลิเคชัน iOS อย่าง Podcasts ยังมีข้อสรุปที่แน่ชัดอีกประการหนึ่งคือ จะไม่มีป้ายกำกับข้อความใดที่เลือกได้และข้อความทั้งหมดกลมกลืนไปกับแบบอักษรของระบบของเครื่อง และจะใช้ธีมสีของระบบ (โหมดมืด) ที่ฉันเลือกไว้ด้วย

แอป Podcasts ในโหมดมืด
แอป Podcasts รองรับโหมดสว่างและโหมดมืด
แอป Podcasts ในโหมดสว่าง
แอปใช้แบบอักษรของระบบเริ่มต้น

การใช้ประโยชน์จากพร็อพเพอร์ตี้ CSS ของ user-select ที่มีค่า none จะช่วยป้องกันการเลือกองค์ประกอบ UI โดยไม่ได้ตั้งใจได้ อย่างไรก็ตาม โปรดระวังว่าอย่าใช้พร็อพเพอร์ตี้นี้ในทางที่ผิดเพื่อทำให้เลือกเนื้อหาแอปไม่ได้ ควรใช้สำหรับองค์ประกอบ UI เท่านั้น เช่น ข้อความบนปุ่ม ฯลฯ ค่า system-ui สำหรับพร็อพเพอร์ตี้ CSS font-family ช่วยให้คุณระบุแบบอักษร UI เริ่มต้นของระบบที่จะใช้สำหรับแอปได้ สุดท้าย แอปสามารถทำตามค่ากำหนดรูปแบบสีของผู้ใช้โดยอิงจากตัวเลือก prefers-color-scheme พร้อมตัวเลือกโหมดมืด (ไม่บังคับ) เพื่อลบล้างตัวเลือกนี้ อีกสิ่งหนึ่งที่ต้องตัดสินใจอาจเป็นสิ่งที่เบราว์เซอร์ควรทำเมื่อไปถึงขอบเขตของพื้นที่เลื่อน เช่น ในการใช้งานการดึงเพื่อรีเฟรชที่กำหนดเอง คุณสามารถทำได้โดยใช้พร็อพเพอร์ตี้ CSS overscroll-behavior

แถบชื่อที่กำหนดเอง

เมื่อดูหน้าต่างแอป Podcasts คุณสังเกตเห็นว่าหน้าต่างไม่มีแถบชื่อและแถบเครื่องมือแบบคลาสสิกที่ผสานรวมอยู่ เช่น หน้าต่างเบราว์เซอร์ Safari แต่เป็นประสบการณ์ที่กำหนดเองซึ่งมีลักษณะเหมือนแถบด้านข้างกับหน้าต่างโปรแกรมเล่นหลัก

แถบไทล์และแถบเครื่องมือที่ผสานรวมในเบราว์เซอร์ Safari
แถบชื่อที่ปรับแต่งเองแบบแยกส่วนของแอป Podcasts
แถบชื่อที่ปรับแต่งของ Safari และ Podcasts

ขณะนี้เรากำลังดำเนินการปรับแต่งแถบชื่อไม่ได้ในขณะนี้ อย่างไรก็ตาม คุณสามารถ (และควร) ระบุพร็อพเพอร์ตี้ display และ theme-color ของไฟล์ Manifest ของเว็บแอปเพื่อ กำหนดรูปลักษณ์ของหน้าต่างแอปพลิเคชันและตัดสินใจว่าจะแสดงการควบคุมเบราว์เซอร์เริ่มต้นรายการใด ซึ่งอาจไม่มีการควบคุมเลย

ภาพเคลื่อนไหวที่กระฉับกระเฉง

ภาพเคลื่อนไหวในแอปจะสั้นกระชับและลื่นไหลใน Podcasts ตัวอย่างเช่น เมื่อเปิดลิ้นชักหมายเหตุของตอนทางด้านขวา จะมีการเลื่อนเข้ามาอย่างสวยงาม เมื่อฉันนำ 1 ตอนออกจากการดาวน์โหลดของฉัน ตอนที่เหลือจะลอยขึ้นและใช้พื้นที่ของหน้าจอที่เป็นอิสระจากตอนที่ลบไปแล้ว

แอป Podcasts ที่มีลิ้นชัก "หมายเหตุของตอน" ขยายอยู่
ภาพเคลื่อนไหวในแอป เช่น เมื่อเปิดลิ้นชักได้อย่างรวดเร็ว

ภาพเคลื่อนไหวที่มีประสิทธิภาพในเว็บเป็นไปได้แน่นอนหากคุณคำนึงถึงแนวทางปฏิบัติแนะนำต่างๆ ที่ระบุไว้ในบทความภาพเคลื่อนไหวและประสิทธิภาพ คุณสามารถปรับปรุงภาพเคลื่อนไหวแบบเลื่อนตามที่เห็นได้ทั่วไปในเนื้อหาที่ใส่เลขหน้าหรือภาพสไลด์ของสื่อ โดยใช้ฟีเจอร์สแนปการเลื่อน CSS คุณใช้ Web Animations API เพื่อควบคุมได้อย่างเต็มรูปแบบ

เนื้อหาที่แสดงภายนอกแอป

แอป Podcasts ใน iOS สามารถแสดงเนื้อหาในตำแหน่งอื่นๆ นอกเหนือจากแอปพลิเคชันจริง เช่น ในมุมมองวิดเจ็ตของระบบหรือในรูปแบบคำแนะนำ Siri การมีคำกระตุ้นให้ดำเนินการ (Call-To-Action) เชิงรุกตามการใช้งานที่เพียงแค่แตะก็โต้ตอบด้วยสามารถเพิ่มอัตราการกลับมามีส่วนร่วมของแอปอย่างเช่น Podcasts ได้อย่างมาก

มุมมองวิดเจ็ต iOS แสดงแอป Podcasts ที่แนะนำตอนใหม่ของพอดแคสต์
เนื้อหาแอปจะแสดงนอกแอป Podcasts หลัก

Content Index API ช่วยให้แอปพลิเคชันบอกเบราว์เซอร์ได้ว่าเนื้อหาของ PWA ใดพร้อมใช้งานแบบออฟไลน์ การดำเนินการนี้ช่วยให้เบราว์เซอร์แสดงเนื้อหานี้นอกแอปหลักได้ การมาร์กอัปเนื้อหาที่น่าสนใจในแอปว่าเหมาะสำหรับการเล่นเสียงที่พูดได้ และมาร์กอัปที่มีโครงสร้างโดยทั่วไปจะช่วยให้คุณช่วยให้เครื่องมือค้นหาและผู้ช่วยเสมือน เช่น Google Assistant นำเสนอข้อเสนอของคุณได้อย่างมีประสิทธิภาพสูงสุด

วิดเจ็ตควบคุมสื่อในหน้าจอล็อก

เมื่อเปิดตอนของพอดแคสต์ แอป Podcasts จะแสดงวิดเจ็ตตัวควบคุมที่สวยงามบนหน้าจอล็อก โดยจะแสดงข้อมูลเมตา เช่น อาร์ตเวิร์กของตอน ชื่อตอน และชื่อพอดแคสต์

วิดเจ็ตการเล่นสื่อของ iOS ในหน้าจอล็อกที่แสดงตอนของพอดแคสต์พร้อมข้อมูลเมตาที่สมบูรณ์
คุณควบคุมสื่อที่เล่นในแอปได้จากหน้าจอล็อก

Media Session API ช่วยให้คุณระบุข้อมูลเมตา เช่น อาร์ตเวิร์ก ชื่อแทร็ก ฯลฯ ที่จะปรากฏบนหน้าจอล็อก สมาร์ทวอทช์ หรือวิดเจ็ตสื่ออื่นๆ ในเบราว์เซอร์ได้

ข้อความ Push

ข้อความ Push กลายเป็นเรื่องน่ารำคาญในเว็บแล้ว (แต่ตอนนี้การแจ้งเตือนจะเลิกรบกวนแล้ว) แต่หากใช้อย่างเหมาะสม ก็จะเพิ่มคุณค่าได้มากมาย เช่น แอป iOS Podcasts สามารถเลือกที่จะแจ้งฉันเมื่อมีตอนใหม่ของพอดแคสต์ที่ฉันติดตามหรือแนะนำพอดแคสต์ใหม่ๆ รวมถึงแจ้งเตือนให้ฉันทราบเกี่ยวกับฟีเจอร์ใหม่ๆ ของแอป

แอปพอดแคสต์ iOS ในหน้าจอการตั้งค่า "การแจ้งเตือน" ที่แสดงปุ่มเปิด/ปิดการแจ้งเตือน "ตอนใหม่" เปิดใช้งานอยู่
แอปสามารถส่งข้อความ Push เพื่อแจ้งให้ผู้ใช้ทราบเกี่ยวกับเนื้อหาใหม่ได้

Push API ช่วยให้แอปรับข้อความ Push ได้เพื่อให้คุณแจ้งให้ผู้ใช้ทราบเกี่ยวกับเหตุการณ์สำคัญเกี่ยวกับ PWA ได้ สำหรับการแจ้งเตือนที่ควรเริ่มทำงานในเวลาที่ทราบในอนาคตและที่ไม่ต้องใช้การเชื่อมต่อเครือข่าย ให้ใช้ Notification Triggers API

การติดป้ายไอคอนแอป

เมื่อใดก็ตามที่มีตอนใหม่สำหรับพอดแคสต์ที่ฉันติดตาม ป้ายไอคอนแอปบนไอคอนหน้าจอหลักของ Podcasts จะปรากฏขึ้นอีกครั้ง เพื่อกระตุ้นให้ฉันมีส่วนร่วมกับแอปอีกครั้งโดยไม่รบกวนคุณ

หน้าจอการตั้งค่า iOS ที่แสดงปุ่มสลับ "ป้าย" เปิดใช้งานอยู่
ป้ายเป็นช่องทางเล็กๆ น้อยๆ ที่แอปพลิเคชันใช้ในการแจ้งให้ผู้ใช้ทราบเกี่ยวกับเนื้อหาใหม่

คุณกำหนดป้ายไอคอนแอปได้ด้วย Badging API ซึ่งจะเป็นประโยชน์อย่างยิ่งเมื่อ PWA คิดว่ามีรายการที่ "ยังไม่อ่าน" หรือเมื่อคุณต้องการวิธีดึงดูดความสนใจของผู้ใช้ให้กลับมาที่แอปได้อย่างไม่น่ารำคาญ

การเล่นสื่อมีลำดับความสำคัญเหนือการตั้งค่าโหมดประหยัดพลังงาน

ขณะเล่นสื่อพอดแคสต์ หน้าจออาจปิด แต่ระบบจะไม่เข้าสู่โหมดสแตนด์บาย แอปจะเลือกให้หน้าจอเปิดอยู่เสมอได้เช่นกัน เช่น เพื่อแสดงเนื้อเพลงหรือคำบรรยาย

ค่ากำหนดของ macOS ในส่วน "โหมดประหยัดพลังงาน"
แอปจะเปิดหน้าจอค้างไว้ได้

Screen Wake Lock API ช่วยให้คุณป้องกันไม่ให้หน้าจอปิดหน้าจอ การเล่นสื่อบนเว็บจะป้องกันไม่ให้ระบบเข้าสู่โหมดสแตนด์บายโดยอัตโนมัติ

การค้นพบแอปผ่าน App Store

แม้ว่าแอป Podcasts เป็นส่วนหนึ่งของการใช้งาน macOS บนเดสก์ท็อป แต่ใน iOS แอปจะต้องติดตั้งจาก App Store การค้นหาด่วนสำหรับ podcast, podcasts หรือ apple podcasts จะทำให้แอปใน App Store ปรากฏขึ้นทันที

การค้นหา "พอดแคสต์" ใน iOS App Store จะแสดงแอป Podcasts
ผู้ใช้เรียนรู้วิธีค้นพบแอปใน App Store

แม้ว่า Apple จะไม่อนุญาตให้ใช้ PWA ใน App Store แต่คุณส่ง PWA ที่รวมอยู่ในกิจกรรมบนเว็บที่เชื่อถือได้ใน Android ได้ สคริปต์ bubblewrap ทำให้การดำเนินการนี้เป็นเรื่องที่ไม่ยุ่งยาก สคริปต์นี้ยังเป็นตัวขับเคลื่อนฟีเจอร์การส่งออกแอป Android ของ PWABuilder ภายใน ซึ่งคุณใช้งานได้โดยไม่ต้องสัมผัสบรรทัดคำสั่ง

สรุปฟีเจอร์

ตารางด้านล่างแสดงภาพรวมแบบกะทัดรัดของฟีเจอร์ทั้งหมด และแสดงรายการแหล่งข้อมูลที่เป็นประโยชน์ต่อการตระหนักถึงฟีเจอร์เหล่านั้นบนเว็บ

ฟีเจอร์ แหล่งข้อมูลที่มีประโยชน์สำหรับการดำเนินการนี้บนเว็บ
ทำงานแบบออฟไลน์ได้
มีเนื้อหาแบบออฟไลน์และเล่นสื่อได้
การดาวน์โหลดในเบื้องหลังเชิงรุก
การแชร์และการโต้ตอบกับแอปพลิเคชันอื่น
การรีเฟรชแอปที่ทำงานอยู่เบื้องหลัง
สถานะซิงค์ข้อมูลผ่านระบบคลาวด์
การควบคุมด้วยคีย์สื่อสำหรับฮาร์ดแวร์
การทำงานหลายอย่างพร้อมกันและทางลัดของแอป
การดำเนินการด่วนในเมนูตามบริบท
ดำเนินการเป็นแอปเริ่มต้น
การผสานรวมระบบไฟล์ในเครื่อง
รูปลักษณ์ของแพลตฟอร์ม
แถบชื่อที่กำหนดเอง
ภาพเคลื่อนไหวที่สั้นกระชับ
เนื้อหาที่แสดงภายนอกแอป
วิดเจ็ตตัวควบคุมสื่อในหน้าจอล็อก
ข้อความ Push
การติดป้ายไอคอนแอป
การเล่นสื่อมีผลเหนือการตั้งค่าโหมดประหยัดพลังงาน
การค้นพบแอปผ่าน App Store

บทสรุป

PWA ก้าวหน้าไปอย่างมากตั้งแต่เปิดตัวในปี 2015 ในบริบทของ Project Fugu 🐡 ทีม Chromium จากหลายบริษัทกำลังพยายามอุดช่องโหว่ที่เหลืออยู่ การทำตามคำแนะนำในบทความนี้บางข้อจะช่วยให้คุณเข้าใกล้ความรู้สึกที่คล้ายกับแอปมากขึ้น และทำให้ผู้ใช้ลืมว่ากำลังมี "แค่เว็บไซต์" เพราะจริงๆ แล้วผู้ใช้ส่วนใหญ่จะไม่สนใจว่าแอปของคุณสร้างขึ้นอย่างไร (และทำไมผู้ใช้จึงควร) ตราบใดที่ยังรู้สึกว่าเป็นแอปจริง

ข้อความแสดงการยอมรับ

บทความนี้ได้รับการตรวจสอบโดย Kayce Basques, Joe Medley, Joshua Bell, Dion Almaer, Ade Oshineye, Pete LePage, Sam Thorogood, Reilly Granteและเจฟฟ์ส