chrome.fileBrowserHandler

คำอธิบาย

ใช้ chrome.fileBrowserHandler API เพื่อขยายโปรแกรมเรียกดูไฟล์ของ Chrome OS ตัวอย่างเช่น คุณใช้ API นี้เพื่ออนุญาตให้ผู้ใช้อัปโหลดไฟล์ไปยังเว็บไซต์ของคุณได้

แนวคิดและการใช้งาน

โปรแกรมเรียกดูไฟล์ของ ChromeOS จะปรากฏขึ้นเมื่อผู้ใช้กด Alt+Shift+M หรือเชื่อมต่ออุปกรณ์จัดเก็บข้อมูลภายนอก เช่น การ์ด SD, คีย์ USB, ไดรฟ์ภายนอก หรือกล้องดิจิทัล นอกจากแสดงไฟล์ในอุปกรณ์ภายนอกแล้ว โปรแกรมเรียกดูไฟล์ยังแสดงไฟล์ที่ผู้ใช้บันทึกไว้ในระบบก่อนหน้านี้ได้ด้วย

เมื่อผู้ใช้เลือกไฟล์อย่างน้อย 1 ไฟล์ โปรแกรมเรียกดูไฟล์จะเพิ่มปุ่มที่แสดงถึงตัวแฮนเดิลที่ถูกต้องสำหรับไฟล์เหล่านั้น เช่น ในภาพหน้าจอต่อไปนี้ ให้เลือกไฟล์ที่มี ".png" คำต่อท้ายจะแสดงผลลัพธ์เป็น "บันทึกลงในแกลเลอรี" ที่ผู้ใช้สามารถคลิกได้

วันที่ โปรแกรมเรียกดูไฟล์ของ ChromeOS
โปรแกรมเรียกดูไฟล์ของ ChromeOS

สิทธิ์

fileBrowserHandler

คุณต้องประกาศสิทธิ์ "fileBrowserHandler" ในไฟล์ Manifest ของส่วนขยาย

ความพร้อมใช้งาน

ChromeOS เท่านั้น เบื้องหน้าเท่านั้น

คุณต้องใช้ฟิลด์ "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

พารามิเตอร์