คำอธิบาย
ใช้ offscreen API เพื่อสร้างและจัดการเอกสารนอกหน้าจอ
สิทธิ์
offscreenหากต้องการใช้ Offscreen API ให้ประกาศสิทธิ์ "offscreen" ใน ไฟล์ Manifest ของส่วนขยาย เช่น
{
"name": "My extension",
...
"permissions": [
"offscreen"
],
...
}
ความพร้อมใช้งาน
แนวคิดและการใช้งาน
Service Worker ไม่มีสิทธิ์เข้าถึง DOM และเว็บไซต์จำนวนมากมีนโยบายความปลอดภัยของเนื้อหาที่จำกัดฟังก์ชันการทำงานของ Content Script Offscreen API ช่วยให้ส่วนขยายใช้ DOM API ในเอกสารที่ซ่อนอยู่ได้โดยไม่ขัดขวางประสบการณ์ของผู้ใช้ด้วยการเปิดหน้าต่างหรือแท็บใหม่ runtime API เป็น API ของส่วนขยายเพียงรายการเดียว
ที่เอกสารนอกหน้าจอรองรับ
ระบบจะจัดการหน้าเว็บที่โหลดเป็นเอกสารนอกหน้าจอแตกต่างจากหน้าเว็บประเภทอื่นๆ ของส่วนขยาย
สิทธิ์ของส่วนขยายจะมีผลกับเอกสารนอกหน้าจอด้วย แต่มีการจำกัดการเข้าถึง API ของส่วนขยาย ตัวอย่างเช่น เนื่องจาก chrome.runtime API เป็น API ของส่วนขยายเพียงรายการเดียวที่เอกสารนอกหน้าจอรองรับ จึงต้องจัดการการรับส่งข้อความโดยใช้สมาชิกของ API ดังกล่าว
เอกสารนอกหน้าจอมีลักษณะการทำงานแตกต่างจากหน้าเว็บปกติในลักษณะอื่นๆ ดังนี้
- URL ของเอกสารนอกหน้าจอต้องเป็นไฟล์ HTML แบบคงที่ที่รวมอยู่ในส่วนขยาย
- เอกสารนอกหน้าจอไม่สามารถโฟกัสได้
- เอกสารนอกหน้าจอเป็นอินสแตนซ์ของ
windowแต่ค่าของพร็อพเพอร์ตี้openerจะเป็นnullเสมอ - แม้ว่าแพ็กเกจส่วนขยายจะมีเอกสารนอกหน้าจอหลายรายการได้ แต่ส่วนขยายที่ติดตั้งแล้วจะเปิดได้ครั้งละ 1 รายการเท่านั้น หากส่วนขยายทำงานในโหมดแยกโดยมีโปรไฟล์ไม่ระบุตัวตนที่ใช้งานอยู่ โปรไฟล์ปกติและโปรไฟล์ไม่ระบุตัวตนแต่ละโปรไฟล์จะมีเอกสารนอกหน้าจอได้ 1 รายการ
ใช้ chrome.offscreen.createDocument() และ
chrome.offscreen.closeDocument() เพื่อสร้างและปิดเอกสารนอกหน้าจอ
createDocument() ต้องใช้ url ของเอกสาร เหตุผล และเหตุผลรองรับ
chrome.offscreen.createDocument({
url: 'off_screen.html',
reasons: ['CLIPBOARD'],
justification: 'reason for needing the document',
});
เหตุผล
ดูรายการเหตุผลที่ใช้ได้ในส่วนเหตุผล ระบบจะตั้งค่าเหตุผลในระหว่างการสร้างเอกสารเพื่อกำหนดอายุการใช้งานของเอกสาร เหตุผล AUDIO_PLAYBACK จะตั้งค่าให้เอกสารปิดหลังจากไม่มีการเล่นเสียงเป็นเวลา 30 วินาที เหตุผลอื่นๆ ทั้งหมดจะไม่กำหนดขีดจำกัดอายุการใช้งาน
ตัวอย่าง
รักษาวงจรของเอกสารนอกหน้าจอ
ตัวอย่างต่อไปนี้แสดงวิธีตรวจสอบว่าเอกสารนอกหน้าจอมีอยู่ ฟังก์ชัน
setupOffscreenDocument() จะเรียก runtime.getContexts() เพื่อค้นหา
เอกสารนอกหน้าจอที่มีอยู่ หรือสร้างเอกสารหากยังไม่มี
let creating; // A global promise to avoid concurrency issues
async function setupOffscreenDocument(path) {
// Check all windows controlled by the service worker to see if one
// of them is the offscreen document with the given path
const offscreenUrl = chrome.runtime.getURL(path);
const existingContexts = await chrome.runtime.getContexts({
contextTypes: ['OFFSCREEN_DOCUMENT'],
documentUrls: [offscreenUrl]
});
if (existingContexts.length > 0) {
return;
}
// create offscreen document
if (creating) {
await creating;
} else {
creating = chrome.offscreen.createDocument({
url: path,
reasons: ['CLIPBOARD'],
justification: 'reason for needing the document',
});
await creating;
creating = null;
}
}
ก่อนส่งข้อความไปยังเอกสารนอกหน้าจอ ให้เรียก setupOffscreenDocument() เพื่อตรวจสอบว่าเอกสารมีอยู่ ดังที่แสดงในตัวอย่างต่อไปนี้
chrome.action.onClicked.addListener(async () => {
await setupOffscreenDocument('off_screen.html');
// Send message to offscreen document
chrome.runtime.sendMessage({
type: '...',
target: 'offscreen',
data: '...'
});
});
ดูตัวอย่างฉบับเต็มได้ที่การสาธิต offscreen-clipboard และ offscreen-dom ใน GitHub
ก่อน Chrome 116: ตรวจสอบว่าเอกสารนอกหน้าจอเปิดอยู่หรือไม่
runtime.getContexts() ได้เพิ่มใน Chrome 116 ใน Chrome เวอร์ชันก่อนหน้า ให้ใช้ clients.matchAll()
เพื่อตรวจสอบเอกสารนอกหน้าจอที่มีอยู่
async function hasOffscreenDocument() {
if ('getContexts' in chrome.runtime) {
const contexts = await chrome.runtime.getContexts({
contextTypes: ['OFFSCREEN_DOCUMENT'],
documentUrls: [OFFSCREEN_DOCUMENT_PATH]
});
return Boolean(contexts.length);
} else {
const matchedClients = await clients.matchAll();
return matchedClients.some(client => {
return client.url.includes(chrome.runtime.id);
});
}
}
ประเภท
CreateParameters
พร็อพเพอร์ตี้
-
justification
สตริง
สตริงที่นักพัฒนาแอปให้ไว้ซึ่งอธิบายรายละเอียดเพิ่มเติมเกี่ยวกับความจำเป็นของบริบทเบื้องหลัง User Agent _อาจ_ ใช้สตริงนี้ในการแสดงต่อผู้ใช้
-
reasons
Reason[]
เหตุผลที่ส่วนขยายสร้างเอกสารนอกหน้าจอ
-
url
สตริง
URL (สัมพัทธ์) ที่จะโหลดในเอกสาร
Reason
ค่าแจกแจง
"TESTING"
เหตุผลที่ใช้เพื่อการทดสอบเท่านั้น
"AUDIO_PLAYBACK"
ระบุว่าเอกสารนอกหน้าจอมีหน้าที่รับผิดชอบในการเล่นเสียง
"IFRAME_SCRIPTING"
ระบุว่าเอกสารนอกหน้าจอต้องฝังและเขียนสคริปต์ iframe เพื่อแก้ไขเนื้อหาของ iframe
"DOM_SCRAPING"
ระบุว่าเอกสารนอกหน้าจอต้องฝัง iframe และดึงข้อมูล DOM เพื่อแยกข้อมูล
"BLOBS"
ระบุว่าเอกสารนอกหน้าจอต้องโต้ตอบกับออบเจ็กต์ Blob (รวมถึง URL.createObjectURL())
"DOM_PARSER"
ระบุว่าเอกสารนอกหน้าจอต้องใช้ DOMParser API
"USER_MEDIA"
ระบุว่าเอกสารนอกหน้าจอต้องโต้ตอบกับสตรีมสื่อจากสื่อของผู้ใช้ (เช่น getUserMedia())
"DISPLAY_MEDIA"
ระบุว่าเอกสารนอกหน้าจอต้องโต้ตอบกับสตรีมสื่อจากสื่อที่แสดง (เช่น getDisplayMedia())
"WEB_RTC"
ระบุว่าเอกสารนอกหน้าจอต้องใช้ WebRTC API
"CLIPBOARD"
ระบุว่าเอกสารนอกหน้าจอต้องโต้ตอบกับ Clipboard API
"LOCAL_STORAGE"
ระบุว่าเอกสารนอกหน้าจอต้องเข้าถึง localStorage
"WORKERS"
ระบุว่าเอกสารนอกหน้าจอต้องสร้าง Worker
"BATTERY_STATUS"
ระบุว่าเอกสารนอกหน้าจอต้องใช้ navigator.getBattery
"MATCH_MEDIA"
ระบุว่าเอกสารนอกหน้าจอต้องใช้ window.matchMedia
"GEOLOCATION"
ระบุว่าเอกสารนอกหน้าจอต้องใช้ navigator.geolocation
เมธอด
closeDocument()
chrome.offscreen.closeDocument(): Promise<void>
ปิดเอกสารนอกหน้าจอที่เปิดอยู่สำหรับส่วนขยาย
การคืนสินค้า
-
Promise<void>
Promise ที่แสดงผลเมื่อเอกสารนอกหน้าจอถูกปิด
createDocument()
chrome.offscreen.createDocument(
parameters: CreateParameters,
): Promise<void>
สร้างเอกสารนอกหน้าจอใหม่สำหรับส่วนขยาย
พารามิเตอร์
-
parameters
พารามิเตอร์ที่อธิบายเอกสารนอกหน้าจอที่จะสร้าง
การคืนสินค้า
-
Promise<void>
Promise ที่แสดงผลเมื่อสร้างเอกสารนอกหน้าจอและโหลดหน้าเว็บเริ่มต้นเสร็จสมบูรณ์
hasDocument()
chrome.offscreen.hasDocument(): Promise<boolean>
กำหนดว่าส่วนขยายมีเอกสารที่ใช้งานอยู่หรือไม่
การคืนสินค้า
-
Promise<boolean>
Promise ที่แสดงผลพร้อมผลลัพธ์ว่าส่วนขยายมีเอกสารนอกหน้าจอที่ใช้งานอยู่หรือไม่