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

พร็อพเพอร์ตี้

  • รายการ

    any[]

    อาร์เรย์ของอินสแตนซ์ Entry ที่แสดงไฟล์ที่เป็นเป้าหมายของการดำเนินการนี้ (เลือกในเบราว์เซอร์ไฟล์ ChromeOS)

  • tab_id

    ตัวเลข ไม่บังคับ

    รหัสของแท็บที่ทำให้เกิดเหตุการณ์นี้ รหัสแท็บจะซ้ำกันไม่ได้ภายในเซสชันของเบราว์เซอร์

กิจกรรม

onExecute

chrome.fileBrowserHandler.onExecute.addListener(
  callback: function,
)

เริ่มทํางานเมื่อมีการดําเนินการในระบบไฟล์จากโปรแกรมดูไฟล์ ChromeOS

พารามิเตอร์