คำอธิบาย
ใช้ chrome.fileBrowserHandler
API เพื่อขยายโปรแกรมเรียกดูไฟล์ของ Chrome OS ตัวอย่างเช่น คุณใช้ API นี้เพื่ออนุญาตให้ผู้ใช้อัปโหลดไฟล์ไปยังเว็บไซต์ของคุณได้
แนวคิดและการใช้งาน
โปรแกรมเรียกดูไฟล์ของ ChromeOS จะปรากฏขึ้นเมื่อผู้ใช้กด Alt+Shift+M หรือเชื่อมต่ออุปกรณ์จัดเก็บข้อมูลภายนอก เช่น การ์ด SD, คีย์ USB, ไดรฟ์ภายนอก หรือกล้องดิจิทัล นอกจากแสดงไฟล์ในอุปกรณ์ภายนอกแล้ว โปรแกรมเรียกดูไฟล์ยังแสดงไฟล์ที่ผู้ใช้บันทึกไว้ในระบบก่อนหน้านี้ได้ด้วย
เมื่อผู้ใช้เลือกไฟล์อย่างน้อย 1 ไฟล์ โปรแกรมเรียกดูไฟล์จะเพิ่มปุ่มที่แสดงถึงตัวแฮนเดิลที่ถูกต้องสำหรับไฟล์เหล่านั้น เช่น ในภาพหน้าจอต่อไปนี้ ให้เลือกไฟล์ที่มี ".png" คำต่อท้ายจะแสดงผลลัพธ์เป็น "บันทึกลงในแกลเลอรี" ที่ผู้ใช้สามารถคลิกได้
สิทธิ์
fileBrowserHandler
คุณต้องประกาศสิทธิ์ "fileBrowserHandler"
ในไฟล์ Manifest ของส่วนขยาย
ความพร้อมใช้งาน
คุณต้องใช้ฟิลด์ "file_browser_handlers"
เพื่อลงทะเบียนส่วนขยายเป็นตัวแฮนเดิลของไฟล์อย่างน้อย 1 ประเภท และคุณควรเตรียมไอคอนขนาด 16 x 16 ที่จะแสดงบนปุ่มด้วย เช่น
{
"name": "My extension",
...
"file_browser_handlers": [
{
"id": "upload",
"default_title": "Save to Gallery", // What the button will display
"file_filters": [
"filesystem:*.jpg", // To match all files, use "filesystem:*.*"
"filesystem:*.jpeg",
"filesystem:*.png"
]
}
],
"permissions" : [
"fileBrowserHandler"
],
"icons": {
"16": "icon16.png",
"48": "icon48.png",
"128": "icon128.png"
},
...
}
ใช้งานตัวแฮนเดิลโปรแกรมเรียกดูไฟล์
หากต้องการใช้ API นี้ คุณต้องใช้ฟังก์ชันที่จัดการเหตุการณ์ onExecute
ของ chrome.fileBrowserHandler
ระบบจะเรียกใช้ฟังก์ชันของคุณเมื่อใดก็ตามที่ผู้ใช้คลิกปุ่มที่แสดงตัวแฮนเดิลเบราว์เซอร์ไฟล์ ใช้ File System API ในฟังก์ชันเพื่อรับสิทธิ์เข้าถึงเนื้อหาของไฟล์ มีตัวอย่างดังต่อไปนี้
chrome.fileBrowserHandler.onExecute.addListener(async (id, details) => {
if (id !== 'upload') {
return; // check if you have multiple file_browser_handlers
}
for (const entry of detail.entries) {
// the FileSystemFileEntry doesn't have a Promise API, wrap in one
const file = await new Promise((resolve, reject) => {
entry.file(resolve, reject);
});
const buffer = await file.arrayBuffer();
// do something with buffer
}
});
ตัวแฮนเดิลเหตุการณ์ส่งผ่านอาร์กิวเมนต์ 2 รายการดังนี้
id
- ค่า
id
จากไฟล์ Manifest หากส่วนขยายของคุณใช้ตัวแฮนเดิลหลายตัว คุณสามารถตรวจสอบค่ารหัสเพื่อดูว่าตัวแฮนเดิลใดเริ่มทำงาน details
- ออบเจ็กต์ที่อธิบายเหตุการณ์ คุณจะรับไฟล์ที่ผู้ใช้เลือกได้จากช่อง
entries
ของออบเจ็กต์นี้ ซึ่งเป็นอาร์เรย์ของออบเจ็กต์FileSystemFileEntry
ประเภท
FileHandlerExecuteEventDetails
เพย์โหลดรายละเอียดเหตุการณ์สำหรับเหตุการณ์ fileBrowserHandler.onExecute
พร็อพเพอร์ตี้
-
รายการ
ทั้งหมด[]
อาร์เรย์ของอินสแตนซ์รายการที่แสดงถึงไฟล์ที่เป็นเป้าหมายของการดำเนินการนี้ (เลือกในเบราว์เซอร์ไฟล์ ChromeOS)
-
tab_id
หมายเลข ไม่บังคับ
รหัสของแท็บที่ทำให้เกิดเหตุการณ์นี้ รหัสแท็บจะไม่ซ้ำกันในเซสชันเบราว์เซอร์
กิจกรรม
onExecute
chrome.fileBrowserHandler.onExecute.addListener(
callback: function,
)
เริ่มทำงานเมื่อมีการเรียกใช้การทำงานของระบบไฟล์จากเบราว์เซอร์ไฟล์ ChromeOS
พารามิเตอร์
-
Callback
ฟังก์ชัน
พารามิเตอร์
callback
มีลักษณะดังนี้(id: string, details: FileHandlerExecuteEventDetails) => void
-
id
สตริง
-
รายละเอียด
-