說明
使用 chrome.action
API 控制 Google Chrome 工具列中的擴充功能圖示。
可用性
資訊清單
如要使用 chrome.action
API,請指定 "manifest_version"
為 3
,並在資訊清單檔案中加入 "action"
鍵。
{
"name": "Action Extension",
...
"action": {
"default_icon": { // optional
"16": "images/icon16.png", // optional
"24": "images/icon24.png", // optional
"32": "images/icon32.png" // optional
},
"default_title": "Click Me", // optional, shown in tooltip
"default_popup": "popup.html" // optional
},
...
}
"action"
鍵 (以及子鍵) 為選用項目。未包含的擴充功能仍會顯示在工具列中,供你存取該擴充功能的選單。因此,建議您一律納入至少 "action"
和 "default_icon"
鍵。
概念和用法
UI 的部分
圖示
圖示是擴充功能工具列上的主要圖片,由資訊清單的 "action"
鍵中的 "default_icon"
鍵設定。圖示的寬度和高度必須為 16 個裝置無關像素 (DIP)。
"default_icon"
鍵是圖片路徑大小的字典。Chrome 會使用這些圖示選擇要使用的圖片縮放比例。如果找不到完全相符結果,Chrome 會選取最接近的可用項目並縮放至適合圖片,這可能會影響圖片品質。
由於縮放比例係數 (例如 1.5 或 1.2 倍) 的裝置越來越常見,因此建議您為圖示提供多種尺寸。這也有助於您的擴充功能日後不受圖示顯示大小變更影響。不過,如果只提供單一大小,"default_icon"
鍵也可以設為字串,其中包含單一圖示的路徑,而非字典。
您也可以呼叫 action.setIcon()
,以程式輔助方式設定擴充功能圖示,方法是指定不同的圖片路徑,或使用 HTML 畫布元素提供動態產生的圖示;如果是來自擴充功能 Service Worker 的設定,則可使用離線畫布 API。
const canvas = new OffscreenCanvas(16, 16);
const context = canvas.getContext('2d');
context.clearRect(0, 0, 16, 16);
context.fillStyle = '#00FF00'; // Green
context.fillRect(0, 0, 16, 16);
const imageData = context.getImageData(0, 0, 16, 16);
chrome.action.setIcon({imageData: imageData}, () => { /* ... */ });
如果是封裝的擴充功能 (從 .crx 檔案安裝),則可使用 Blink 轉譯引擎可顯示的大部分格式圖片,包括 PNG、JPEG、BMP、ICO 等。不支援 SVG。未封裝的擴充功能必須使用 PNG 圖片。
工具提示 (標題)
當使用者將滑鼠游標懸停在工具列的擴充功能圖示上時,系統就會顯示工具提示或標題。當按鈕獲得焦點時,螢幕閱讀器也會朗讀這段文字。
預設工具提示會使用 manifest.json
中 "action"
鍵的 "default_title"
欄位設定。您也可以透過呼叫 action.setTitle()
以程式輔助方式設定。
徽章
動作可選擇顯示「徽章」(圖示上方會顯示一小段文字)。這可讓您更新動作,以顯示少量關於擴充功能的狀態資訊 (例如計數器)。徽章含有文字元件和背景顏色。由於空間有限,建議標記文字長度不要超過 4 個字元。
如要建立徽章,請呼叫 action.setBadgeBackgroundColor()
和 action.setBadgeText()
,以程式輔助方式設定徽章。資訊清單中沒有預設徽章設定。徽章顏色值可以是 0 到 255 之間四個整數的陣列,用於組成徽章的 RGBA 顏色,也可以是包含 CSS 顏色值的字串。
chrome.action.setBadgeBackgroundColor(
{color: [0, 255, 0, 0]}, // Green
() => { /* ... */ },
);
chrome.action.setBadgeBackgroundColor(
{color: '#00FF00'}, // Also green
() => { /* ... */ },
);
chrome.action.setBadgeBackgroundColor(
{color: 'green'}, // Also, also green
() => { /* ... */ },
);
彈出式廣告
當使用者在工具列中按一下擴充功能的動作按鈕時,系統就會顯示動作的彈出式視窗。彈出式視窗可以包含任何您想要的 HTML 內容,且會自動調整其大小,以符合內容。彈出式視窗的大小必須介於 25x25 和 800x600 像素之間。
彈出式視窗最初是由 manifest.json
檔案 "action"
鍵中的 "default_popup"
屬性設定。如果有,這個屬性應指向擴充功能目錄中的相對路徑。也可以使用 action.setPopup()
方法以動態方式更新,使其指向不同的相對路徑。
用途
個別分頁狀態
擴充功能動作可針對每個分頁設定不同的狀態。如要為個別分頁設定值,請在 action
API 的設定方法中使用 tabId
屬性。舉例來說,如要為特定分頁設定標記文字,請執行下列步驟:
function getTabId() { /* ... */}
function getTabBadge() { /* ... */}
chrome.action.setBadgeText(
{
text: getTabBadge(tabId),
tabId: getTabId(),
},
() => { ... }
);
如果省略 tabId
屬性,系統會將設定視為全域設定。特定分頁設定的優先順序高於通用設定。
已啟用狀態
根據預設,每個分頁都會啟用 (可點選) 工具列動作。您可以使用 action.enable()
和 action.disable()
方法控管這項設定。這只會影響是否將彈出式視窗 (如有) 或 action.onClicked
事件傳送至擴充功能;不會影響動作在工具列中的顯示情形。
範例
以下範例說明在擴充功能中使用動作的常見方式。如要試用這個 API,請從 chrome-extension-samples 存放區安裝 Action API 範例。
顯示彈出式視窗
擴充功能會在使用者點選擴充功能的動作時顯示彈出式視窗。如要在自己的擴充功能中實作這項功能,請在 manifest.json
中宣告彈出式視窗,並指定 Chrome 應在彈出式視窗中顯示的內容。
// manifest.json
{
"name": "Action popup demo",
"version": "1.0",
"manifest_version": 3,
"action": {
"default_title": "Click to view a popup",
"default_popup": "popup.html"
}
}
<!-- popup.html -->
<!DOCTYPE html>
<html>
<head>
<style>
html {
min-height: 5em;
min-width: 10em;
background: salmon;
}
</style>
</head>
<body>
<p>Hello, world!</p>
</body>
</html>
點擊時插入內容指令碼
擴充功能的常見模式是使用擴充功能的動作公開主要功能。以下範例說明此模式。使用者按一下動作時,擴充功能會在目前的頁面中插入內容指令碼。接著,內容指令碼會顯示快訊,確認一切運作正常。
// manifest.json
{
"name": "Action script injection demo",
"version": "1.0",
"manifest_version": 3,
"action": {
"default_title": "Click to show an alert"
},
"permissions": ["activeTab", "scripting"],
"background": {
"service_worker": "background.js"
}
}
// background.js
chrome.action.onClicked.addListener((tab) => {
chrome.scripting.executeScript({
target: {tabId: tab.id},
files: ['content.js']
});
});
// content.js
alert('Hello, world!');
使用 declarativeContent 模擬動作
這個範例說明擴充功能的背景邏輯如何 (a) 預設停用動作,以及 (b) 使用 declarativeContent 來在特定網站上啟用動作。
// service-worker.js
// Wrap in an onInstalled callback to avoid unnecessary work
// every time the service worker is run
chrome.runtime.onInstalled.addListener(() => {
// Page actions are disabled by default and enabled on select tabs
chrome.action.disable();
// Clear all rules to ensure only our expected rules are set
chrome.declarativeContent.onPageChanged.removeRules(undefined, () => {
// Declare a rule to enable the action on example.com pages
let exampleRule = {
conditions: [
new chrome.declarativeContent.PageStateMatcher({
pageUrl: {hostSuffix: '.example.com'},
})
],
actions: [new chrome.declarativeContent.ShowAction()],
};
// Finally, apply our new array of rules
let rules = [exampleRule];
chrome.declarativeContent.onPageChanged.addRules(rules);
});
});
類型
OpenPopupOptions
屬性
-
windowId
號碼 選填
要開啟動作彈出式視窗的視窗 ID。如未指定,則會預設為目前使用中的視窗。
TabDetails
屬性
-
tabId
號碼 選填
要查詢狀態的分頁 ID。如果未指定分頁,系統會傳回非分頁專屬狀態。
UserSettings
與擴充功能動作相關的使用者指定的設定集合。
屬性
-
isOnToolbar
布林值
擴充功能的動作圖示是否顯示在瀏覽器視窗的頂層工具列上 (也就是使用者是否已「固定」擴充功能)。
UserSettingsChange
屬性
-
isOnToolbar
boolean 選填
擴充功能的動作圖示是否顯示在瀏覽器視窗的頂層工具列上 (也就是使用者是否已「固定」擴充功能)。
方法
disable()
chrome.action.disable(
tabId?: number,
callback?: function,
)
停用分頁的動作。
參數
-
tabId
號碼 選填
您要修改動作的分頁 ID。
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
Promise<void>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
enable()
chrome.action.enable(
tabId?: number,
callback?: function,
)
啟用分頁動作。根據預設,系統會啟用動作。
參數
-
tabId
號碼 選填
您要修改動作的分頁 ID。
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
Promise<void>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
getBadgeBackgroundColor()
chrome.action.getBadgeBackgroundColor(
details: TabDetails,
callback?: function,
)
取得動作的背景顏色。
參數
-
詳細資料
-
回呼
函式 選用
callback
參數如下所示:(result: ColorArray) => void
-
結果
-
傳回
-
Promise<browserAction.ColorArray>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
getBadgeText()
chrome.action.getBadgeText(
details: TabDetails,
callback?: function,
)
取得動作的徽章文字。如果未指定分頁,系統會傳回非分頁專屬的徽章文字。如果已啟用 displayActionCountAsBadgeText,則系統會傳回預留位置文字,除非有 declarativeNetRequestFeedback 權限,或是提供特定分頁的徽章文字。
參數
-
詳細資料
-
回呼
函式 選用
callback
參數如下所示:(result: string) => void
-
結果
字串
-
傳回
-
Promise<string>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
getBadgeTextColor()
chrome.action.getBadgeTextColor(
details: TabDetails,
callback?: function,
)
取得動作的文字顏色。
參數
-
詳細資料
-
回呼
函式 選用
callback
參數如下所示:(result: ColorArray) => void
-
結果
-
傳回
-
Promise<browserAction.ColorArray>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
getPopup()
chrome.action.getPopup(
details: TabDetails,
callback?: function,
)
取得設為此動作彈出式視窗的 HTML 文件。
參數
-
詳細資料
-
回呼
函式 選用
callback
參數如下所示:(result: string) => void
-
結果
字串
-
傳回
-
Promise<string>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
參數
-
詳細資料
-
回呼
函式 選用
callback
參數如下所示:(result: string) => void
-
結果
字串
-
傳回
-
Promise<string>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
getUserSettings()
chrome.action.getUserSettings(
callback?: function,
)
傳回使用者指定的擴充功能動作相關設定。
參數
-
回呼
函式 選用
callback
參數如下所示:(userSettings: UserSettings) => void
-
userSettings
-
傳回
-
Promise<UserSettings>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
isEnabled()
chrome.action.isEnabled(
tabId?: number,
callback?: function,
)
指出是否為分頁啟用擴充功能動作 (如未提供 tabId
,則設為全域)。僅使用 declarativeContent
啟用的動作一律會傳回 false。
參數
-
tabId
號碼 選填
要查看其啟用狀態的分頁 ID。
-
回呼
函式 選用
callback
參數如下所示:(isEnabled: boolean) => void
-
isEnabled
布林值
如果已啟用擴充功能動作,則為「是」。
-
傳回
-
Promise<boolean>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
openPopup()
chrome.action.openPopup(
options?: OpenPopupOptions,
callback?: function,
)
開啟擴充功能的彈出式視窗。在 Chrome 118 和 Chrome 126 之間,這項功能僅適用於政策安裝的擴充功能。
參數
-
選項
指定開啟彈出式視窗的選項。
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
Promise<void>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
setBadgeBackgroundColor()
chrome.action.setBadgeBackgroundColor(
details: object,
callback?: function,
)
設定徽章的背景顏色。
參數
-
詳細資料
物件
-
顏色
字串 | ColorArray
陣列包含四個介於 [0,255] 範圍內的整數,用於組成徽章的 RGBA 顏色。例如不透明紅色是
[255, 0, 0, 255]
。可以是包含 CSS 值的字串,且不透明的紅色為#FF0000
或#F00
。 -
tabId
號碼 選填
限制在選取特定分頁的時機。會在分頁關閉時自動重設。
-
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
Promise<void>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
setBadgeText()
chrome.action.setBadgeText(
details: object,
callback?: function,
)
設定動作的徽章文字。徽章會顯示在圖示上方。
參數
-
詳細資料
物件
-
tabId
號碼 選填
限制在選取特定分頁的時機。關閉分頁時會自動重設。
-
文字
string 選填
您可以傳遞任意數量的字元,但空間只能容納約四個字元。如果傳遞空白字串 (
''
),系統會清除徽章文字。如果指定tabId
且text
為空值,系統會清除指定分頁的文字,並預設為全域徽章文字。
-
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
Promise<void>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
setBadgeTextColor()
chrome.action.setBadgeTextColor(
details: object,
callback?: function,
)
設定徽章的文字顏色。
參數
-
詳細資料
物件
-
顏色
string | ColorArray
介於 [0,255] 範圍內的四個整數,構成徽章的 RGBA 顏色。例如不透明紅色是
[255, 0, 0, 255]
。可以是包含 CSS 值的字串,且不透明的紅色為#FF0000
或#F00
。如未設定這個值,系統會自動選擇與徽章底色對比的顏色,以便顯示文字。Alpha 值相當於 0 的顏色不會設定,並且會傳回錯誤。 -
tabId
號碼 選填
限制在選取特定分頁的時機。會在分頁關閉時自動重設。
-
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
Promise<void>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
setIcon()
chrome.action.setIcon(
details: object,
callback?: function,
)
設定動作的圖示。可以將圖示指定為圖片檔的路徑,或是畫布元素中的像素資料,或是圖示為其中一個項目的字典。必須指定 path 或 imageData 屬性。
參數
-
詳細資料
物件
-
imageData
ImageData | 物件 選用
ImageData 物件,或是代表要設定圖示的字典 {size -> ImageData}。如果將圖示指定為字典,系統會根據螢幕像素密度選擇要使用的實際圖片。如果單一螢幕空間單元的圖片像素數量等於
scale
,系統會選取大小為scale
* n 的圖片像素,其中 n 是使用者介面中的圖示尺寸。至少須指定一張圖片。請注意,「details.imageData = foo」等同於「details.imageData = {'16': foo}」 -
路徑
字串 | 物件 選填
相對圖片路徑或字典 {size -> relative image path},指向要設定的圖示。如果圖示是使用字典指定,系統會根據螢幕的像素密度選擇要使用的實際圖片。如果圖片像素數量可容納在一個螢幕空間單位中,且等於
scale
,系統就會選取大小為scale
* n 的圖片,其中 n 是 UI 中圖示的大小。至少須指定一張圖片。請注意,「details.path = foo」等同於「details.path = {'16': foo}」 -
tabId
號碼 選填
限制在選取特定分頁的時機。會在分頁關閉時自動重設。
-
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
承諾<void>
Chrome 96 以上版本Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
setPopup()
chrome.action.setPopup(
details: object,
callback?: function,
)
設定使用者按一下動作圖示時,要以彈出式開啟的 HTML 文件。
參數
-
詳細資料
物件
-
彈出式訊息
字串
在彈出式視窗中顯示的 HTML 檔案的相對路徑。如果設為空字串 (
''
),系統不會顯示彈出式視窗。 -
tabId
號碼 選填
限制在選取特定分頁的時機。會在分頁關閉時自動重設。
-
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
Promise<void>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一函式呼叫中同時使用兩者。保證會以傳遞至回呼的類型來解析。
setTitle()
chrome.action.setTitle(
details: object,
callback?: function,
)
設定動作的標題。這項資訊會顯示在工具提示中。
參數
-
詳細資料
物件
-
tabId
號碼 選填
限制變更時機,僅在選取特定分頁時才會變更。會在分頁關閉時自動重設。
-
title
字串
滑鼠游標經過時,動作應顯示的字串。
-
-
回呼
函式 選用
callback
參數如下所示:() => void
傳回
-
Promise<void>
Promise 適用於 Manifest V3 及以上版本,但為了回溯相容性,提供回呼。您無法在同一個函式呼叫中同時使用這兩種方法。承諾會以傳遞至回呼的相同類型解析。
活動
onClicked
chrome.action.onClicked.addListener(
callback: function,
)
在點選動作圖示時觸發。如果動作含有彈出式視窗,系統就不會觸發這個事件。
onUserSettingsChanged
chrome.action.onUserSettingsChanged.addListener(
callback: function,
)
與擴充功能動作變更相關的使用者指定的設定時觸發。
參數
-
回呼
函式
callback
參數如下所示:(change: UserSettingsChange) => void