คำอธิบาย
ใช้ 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
พร็อพเพอร์ตี้
-
รายการ
any[]
อาร์เรย์ของอินสแตนซ์ Entry ที่แสดงไฟล์ที่เป็นเป้าหมายของการดำเนินการนี้ (เลือกในเบราว์เซอร์ไฟล์ ChromeOS)
-
tab_id
ตัวเลข ไม่บังคับ
รหัสของแท็บที่ทำให้เกิดเหตุการณ์นี้ รหัสแท็บจะซ้ำกันไม่ได้ภายในเซสชันของเบราว์เซอร์
กิจกรรม
onExecute
chrome.fileBrowserHandler.onExecute.addListener(
callback: function,
)
เริ่มทํางานเมื่อมีการดําเนินการในระบบไฟล์จากโปรแกรมดูไฟล์ ChromeOS
พารามิเตอร์
-
Callback
ฟังก์ชัน
พารามิเตอร์
callback
จะมีลักษณะดังนี้(id: string, details: FileHandlerExecuteEventDetails) => void
-
id
สตริง
-
รายละเอียด
-