chrome.action

Mô tả

Sử dụng API chrome.action để kiểm soát biểu tượng của tiện ích trên thanh công cụ Google Chrome.

Các biểu tượng thao tác sẽ xuất hiện trên thanh công cụ của trình duyệt, bên cạnh thanh địa chỉ. Sau khi cài đặt, các tiện ích này sẽ xuất hiện trong trình đơn tiện ích (biểu tượng mảnh ghép). Người dùng có thể ghim biểu tượng tiện ích của bạn vào thanh công cụ.

Phạm vi cung cấp

Chrome 88 trở lên MV3 trở lên

Tệp kê khai

Bạn phải khai báo các khoá sau trong tệp kê khai để sử dụng API này.

"action"

Để sử dụng API chrome.action, hãy chỉ định một "manifest_version"3 và thêm khoá "action" vào tệp kê khai.

{
  "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
  },
  ...
}

Khoá "action" (cùng với các khoá con) là không bắt buộc. Khi không có biểu tượng, tiện ích của bạn vẫn xuất hiện trên thanh công cụ để cung cấp quyền truy cập vào trình đơn của tiện ích. Vì lý do này, bạn nên luôn thêm ít nhất các khoá "action""default_icon".

Khái niệm và cách sử dụng

Các phần của giao diện người dùng

Biểu tượng

Biểu tượng này là hình ảnh chính trên thanh công cụ của tiện ích và được đặt bằng khoá "default_icon" trong khoá "action" của tệp kê khai. Biểu tượng phải có chiều rộng và chiều cao là 16 pixel độc lập với thiết bị (DIP).

Khoá "default_icon" là một từ điển về kích thước cho các đường dẫn đến hình ảnh. Chrome sử dụng các biểu tượng này để chọn tỷ lệ hình ảnh cần dùng. Nếu không tìm thấy kết quả trùng khớp hoàn toàn, Chrome sẽ chọn kết quả gần nhất có sẵn và điều chỉnh tỷ lệ cho vừa với hình ảnh. Điều này có thể ảnh hưởng đến chất lượng hình ảnh.

Vì các thiết bị có hệ số tỷ lệ ít phổ biến như 1,5x hoặc 1,2x đang trở nên phổ biến hơn, nên bạn nên cung cấp nhiều kích thước cho biểu tượng của mình. Điều này cũng giúp tiện ích của bạn không bị ảnh hưởng khi kích thước hiển thị biểu tượng có thể thay đổi trong tương lai. Tuy nhiên, nếu chỉ cung cấp một kích thước, bạn cũng có thể đặt khoá "default_icon" thành một chuỗi có đường dẫn đến một biểu tượng duy nhất thay vì một từ điển.

Bạn cũng có thể gọi action.setIcon() để đặt biểu tượng của tiện ích theo cách lập trình bằng cách chỉ định một đường dẫn hình ảnh khác hoặc cung cấp biểu tượng được tạo động bằng phần tử canvas HTML hoặc nếu đặt từ một worker dịch vụ tiện ích, thì API canvas ngoài màn hình.

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}, () => { /* ... */ });

Đối với các tiện ích được đóng gói (được cài đặt từ tệp .crx), hình ảnh có thể ở hầu hết các định dạng mà công cụ kết xuất Blink có thể hiển thị, bao gồm PNG, JPEG, BMP, ICO và các định dạng khác. Không hỗ trợ SVG. Phần mở rộng chưa đóng gói phải sử dụng hình ảnh PNG.

Chú thích (tiêu đề)

Chú giải công cụ hoặc tiêu đề sẽ xuất hiện khi người dùng di chuột lên biểu tượng của tiện ích trên thanh công cụ. Tên này cũng có trong văn bản hỗ trợ tiếp cận mà trình đọc màn hình đọc khi nút nhận được tiêu điểm.

Chú giải công cụ mặc định được đặt bằng cách sử dụng trường "default_title" của khoá "action" trong manifest.json. Bạn cũng có thể đặt giá trị này theo phương thức lập trình bằng cách gọi action.setTitle().

Huy hiệu

Các thao tác có thể tuỳ ý hiển thị một "huy hiệu" – một đoạn văn bản được xếp lớp lên biểu tượng. Thao tác này cho phép bạn cập nhật thao tác để hiển thị một lượng nhỏ thông tin về trạng thái của tiện ích, chẳng hạn như một bộ đếm. Huy hiệu có một thành phần văn bản và một màu nền. Vì không gian có hạn, nên bạn nên sử dụng văn bản huy hiệu có tối đa 4 ký tự.

Để tạo một huy hiệu, hãy đặt huy hiệu đó theo cách lập trình bằng cách gọi action.setBadgeBackgroundColor()action.setBadgeText(). Không có chế độ cài đặt huy hiệu mặc định trong tệp kê khai. Giá trị màu của huy hiệu có thể là một mảng gồm 4 số nguyên từ 0 đến 255 tạo nên màu RGBA của huy hiệu hoặc một chuỗi có giá trị màu 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
  () => { /* ... */ },
);

Cửa sổ bật lên của một thao tác sẽ xuất hiện khi người dùng nhấp vào nút thao tác của tiện ích trên thanh công cụ. Cửa sổ bật lên có thể chứa mọi nội dung HTML mà bạn muốn và sẽ tự động điều chỉnh kích thước cho phù hợp với nội dung của nó. Kích thước của cửa sổ bật lên phải nằm trong khoảng từ 25x25 đến 800x600 pixel.

Ban đầu, cửa sổ bật lên được đặt theo thuộc tính "default_popup" trong khoá "action" trong tệp manifest.json. Nếu có, thuộc tính này phải trỏ đến một đường dẫn tương đối trong thư mục tiện ích. Bạn cũng có thể cập nhật động để trỏ đến một đường dẫn tương đối khác bằng phương thức action.setPopup().

Trường hợp sử dụng

Trạng thái theo thẻ

Hành động trên tiện ích có thể có nhiều trạng thái cho từng thẻ. Để đặt giá trị cho từng thẻ, hãy dùng thuộc tính tabId trong các phương thức cài đặt của API action. Ví dụ: để đặt văn bản huy hiệu cho một thẻ cụ thể, hãy làm như sau:

function getTabId() { /* ... */}
function getTabBadge() { /* ... */}

chrome.action.setBadgeText(
  {
    text: getTabBadge(tabId),
    tabId: getTabId(),
  },
  () => { ... }
);

Nếu bạn bỏ qua thuộc tính tabId, thì chế độ cài đặt này sẽ được coi là chế độ cài đặt chung. Chế độ cài đặt dành riêng cho thẻ sẽ được ưu tiên hơn chế độ cài đặt chung.

Trạng thái đã bật

Theo mặc định, các thao tác trên thanh công cụ sẽ được bật (có thể nhấp vào) trên mọi thẻ. Bạn có thể thay đổi giá trị mặc định này bằng cách đặt thuộc tính default_state trong khoá action của tệp kê khai. Nếu default_state được đặt thành "disabled", thì thao tác này sẽ bị vô hiệu hoá theo mặc định và phải được bật theo phương thức lập trình để có thể nhấp vào. Nếu default_state được đặt thành "enabled" (mặc định), thì thao tác này sẽ được bật và có thể nhấp vào theo mặc định.

Bạn có thể kiểm soát trạng thái theo phương thức lập trình bằng cách sử dụng các phương thức action.enable()action.disable(). Điều này chỉ ảnh hưởng đến việc cửa sổ bật lên (nếu có) hoặc sự kiện action.onClicked có được gửi đến tiện ích của bạn hay không; điều này không ảnh hưởng đến sự hiện diện của thao tác trong thanh công cụ.

Ví dụ

Các ví dụ sau đây cho thấy một số cách phổ biến mà các thao tác được dùng trong tiện ích. Để dùng thử API này, hãy cài đặt ví dụ về Action API trong kho lưu trữ chrome-extension-samples.

Hiện cửa sổ bật lên

Thông thường, tiện ích sẽ hiển thị một cửa sổ bật lên khi người dùng nhấp vào hành động của tiện ích. Để triển khai việc này trong tiện ích của riêng bạn, hãy khai báo cửa sổ bật lên trong manifest.json và chỉ định nội dung mà Chrome sẽ hiển thị trong cửa sổ bật lên.

// 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>

Chèn tập lệnh nội dung khi nhấp

Một mẫu hình phổ biến cho các tiện ích là hiển thị tính năng chính của chúng bằng cách sử dụng thao tác của tiện ích. Ví dụ sau đây minh hoạ mẫu này. Khi người dùng nhấp vào thao tác này, tiện ích sẽ chèn một tập lệnh nội dung vào trang hiện tại. Sau đó, tập lệnh nội dung sẽ hiển thị một cảnh báo để xác minh rằng mọi thứ đều hoạt động như mong đợi.

// 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!');

Mô phỏng các thao tác bằng declarativeContent

Ví dụ này cho thấy cách logic nền của một tiện ích có thể (a) tắt một thao tác theo mặc định và (b) sử dụng declarativeContent để bật thao tác trên các trang web cụ thể.

// 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);
  });
});

Loại

OpenPopupOptions

Chrome 99 trở lên

Thuộc tính

  • windowId

    number không bắt buộc

    Mã nhận dạng của cửa sổ để mở cửa sổ bật lên thao tác. Mặc định là cửa sổ đang hoạt động nếu bạn không chỉ định.

TabDetails

Thuộc tính

  • tabId

    number không bắt buộc

    Mã của thẻ để truy vấn trạng thái. Nếu không có thẻ nào được chỉ định, thì trạng thái không dành riêng cho thẻ sẽ được trả về.

UserSettings

Chrome 91 trở lên

Tập hợp các chế độ cài đặt do người dùng chỉ định liên quan đến hành động của một tiện ích.

Thuộc tính

  • isOnToolbar

    boolean

    Biểu tượng thao tác của tiện ích có xuất hiện trên thanh công cụ cấp cao nhất của cửa sổ trình duyệt hay không (tức là người dùng có "ghim" tiện ích hay không).

UserSettingsChange

Chrome 130 trở lên

Thuộc tính

  • isOnToolbar

    boolean không bắt buộc

    Biểu tượng thao tác của tiện ích có xuất hiện trên thanh công cụ cấp cao nhất của cửa sổ trình duyệt hay không (tức là người dùng có "ghim" tiện ích hay không).

Phương thức

disable()

chrome.action.disable(
  tabId?: number,
)
: Promise<void>

Tắt thao tác cho một thẻ.

Thông số

  • tabId

    number không bắt buộc

    Mã nhận dạng của thẻ mà bạn muốn sửa đổi hành động.

Giá trị trả về

  • Promise<void>

enable()

chrome.action.enable(
  tabId?: number,
)
: Promise<void>

Cho phép thực hiện thao tác cho một thẻ. Theo mặc định, các thao tác sẽ được bật.

Thông số

  • tabId

    number không bắt buộc

    Mã nhận dạng của thẻ mà bạn muốn sửa đổi hành động.

Giá trị trả về

  • Promise<void>

getBadgeBackgroundColor()

chrome.action.getBadgeBackgroundColor(
  details: TabDetails,
)
: Promise<extensionTypes.ColorArray>

Lấy màu nền của thao tác.

Thông số

Giá trị trả về

getBadgeText()

chrome.action.getBadgeText(
  details: TabDetails,
)
: Promise<string>

Lấy văn bản huy hiệu của thao tác. Nếu không có thẻ nào được chỉ định, thì văn bản huy hiệu không dành riêng cho thẻ sẽ được trả về. Nếu displayActionCountAsBadgeText được bật, thì một văn bản phần giữ chỗ sẽ được trả về, trừ phi có quyền declarativeNetRequestFeedback hoặc văn bản huy hiệu dành riêng cho thẻ được cung cấp.

Thông số

Giá trị trả về

  • Promise<string>

getBadgeTextColor()

Chrome 110 trở lên
chrome.action.getBadgeTextColor(
  details: TabDetails,
)
: Promise<extensionTypes.ColorArray>

Lấy màu văn bản của thao tác.

Thông số

Giá trị trả về

getPopup()

chrome.action.getPopup(
  details: TabDetails,
)
: Promise<string>

Lấy tài liệu HTML được đặt làm cửa sổ bật lên cho thao tác này.

Thông số

Giá trị trả về

  • Promise<string>

getTitle()

chrome.action.getTitle(
  details: TabDetails,
)
: Promise<string>

Lấy tiêu đề của thao tác.

Thông số

Giá trị trả về

  • Promise<string>

getUserSettings()

Chrome 91 trở lên
chrome.action.getUserSettings(): Promise<UserSettings>

Trả về các chế độ cài đặt do người dùng chỉ định liên quan đến hành động của một tiện ích.

Giá trị trả về

isEnabled()

Chrome 110 trở lên
chrome.action.isEnabled(
  tabId?: number,
)
: Promise<boolean>

Cho biết liệu thao tác của tiện ích có được bật cho một thẻ hay không (hoặc trên toàn cục nếu không có tabId nào được cung cấp). Các thao tác chỉ được bật bằng declarativeContent luôn trả về giá trị false.

Thông số

  • tabId

    number không bắt buộc

    Mã nhận dạng của thẻ mà bạn muốn kiểm tra trạng thái đã bật.

Giá trị trả về

  • Promise<boolean>

openPopup()

Chrome 127 trở lên
chrome.action.openPopup(
  options?: OpenPopupOptions,
)
: Promise<void>

Mở cửa sổ bật lên của tiện ích. Từ Chrome 118 đến Chrome 126, tính năng này chỉ dành cho các tiện ích được cài đặt theo chính sách.

Thông số

  • tùy chọn

    OpenPopupOptions không bắt buộc

    Chỉ định các lựa chọn để mở cửa sổ bật lên.

Giá trị trả về

  • Promise<void>

setBadgeBackgroundColor()

chrome.action.setBadgeBackgroundColor(
  details: object,
)
: Promise<void>

Đặt màu nền cho huy hiệu.

Thông số

  • chi tiết

    đối tượng

    • màu

      string | ColorArray

      Một mảng gồm 4 số nguyên trong phạm vi [0,255] tạo nên màu RGBA của huy hiệu. Ví dụ: màu đỏ mờ là [255, 0, 0, 255]. Cũng có thể là một chuỗi có giá trị CSS, với màu đỏ mờ là #FF0000 hoặc #F00.

    • tabId

      number không bắt buộc

      Giới hạn thay đổi khi một thẻ cụ thể được chọn. Tự động đặt lại khi thẻ bị đóng.

Giá trị trả về

  • Promise<void>

setBadgeText()

chrome.action.setBadgeText(
  details: object,
)
: Promise<void>

Đặt văn bản huy hiệu cho thao tác. Huy hiệu này xuất hiện ở trên biểu tượng.

Thông số

  • chi tiết

    đối tượng

    • tabId

      number không bắt buộc

      Giới hạn thay đổi khi một thẻ cụ thể được chọn. Tự động đặt lại khi thẻ bị đóng.

    • văn bản

      chuỗi không bắt buộc

      Bạn có thể truyền bất kỳ số lượng ký tự nào, nhưng chỉ khoảng 4 ký tự có thể vừa với không gian. Nếu bạn truyền một chuỗi trống (''), thì văn bản trên huy hiệu sẽ bị xoá. Nếu bạn chỉ định tabIdtext là giá trị rỗng, thì văn bản cho thẻ được chỉ định sẽ bị xoá và mặc định là văn bản huy hiệu chung.

Giá trị trả về

  • Promise<void>

setBadgeTextColor()

Chrome 110 trở lên
chrome.action.setBadgeTextColor(
  details: object,
)
: Promise<void>

Đặt màu văn bản cho huy hiệu.

Thông số

  • chi tiết

    đối tượng

    • màu

      string | ColorArray

      Một mảng gồm 4 số nguyên trong phạm vi [0,255] tạo nên màu RGBA của huy hiệu. Ví dụ: màu đỏ mờ là [255, 0, 0, 255]. Cũng có thể là một chuỗi có giá trị CSS, với màu đỏ mờ là #FF0000 hoặc #F00. Nếu bạn không đặt giá trị này, hệ thống sẽ tự động chọn một màu tương phản với màu nền của huy hiệu để văn bản xuất hiện. Màu có giá trị alpha tương đương với 0 sẽ không được đặt và sẽ trả về lỗi.

    • tabId

      number không bắt buộc

      Giới hạn thay đổi khi một thẻ cụ thể được chọn. Tự động đặt lại khi thẻ bị đóng.

Giá trị trả về

  • Promise<void>

setIcon()

chrome.action.setIcon(
  details: object,
)
: Promise<void>

Đặt biểu tượng cho thao tác. Bạn có thể chỉ định biểu tượng dưới dạng đường dẫn đến một tệp hình ảnh hoặc dưới dạng dữ liệu pixel từ một phần tử canvas, hoặc dưới dạng từ điển của một trong hai loại đó. Bạn phải chỉ định thuộc tính path hoặc imageData.

Thông số

  • chi tiết

    đối tượng

    • imageData

      ImageData | object không bắt buộc

      Một đối tượng ImageData hoặc một từ điển {size -> ImageData} đại diện cho biểu tượng sẽ được đặt. Nếu biểu tượng được chỉ định dưới dạng từ điển, thì hình ảnh thực tế sẽ được dùng tuỳ thuộc vào mật độ pixel của màn hình. Nếu số lượng pixel hình ảnh vừa với một đơn vị không gian màn hình bằng scale, thì hình ảnh có kích thước scale * n sẽ được chọn, trong đó n là kích thước của biểu tượng trong giao diện người dùng. Bạn phải chỉ định ít nhất một hình ảnh. Xin lưu ý rằng "details.imageData = foo" tương đương với "details.imageData = {'16': foo}"

    • đường dẫn

      string | object không bắt buộc

      Đường dẫn hình ảnh tương đối hoặc từ điển {size -> relative image path} trỏ đến biểu tượng cần đặt. Nếu biểu tượng được chỉ định dưới dạng từ điển, thì hình ảnh thực tế sẽ được dùng tuỳ thuộc vào mật độ pixel của màn hình. Nếu số lượng pixel hình ảnh vừa với một đơn vị không gian màn hình bằng scale, thì hình ảnh có kích thước scale * n sẽ được chọn, trong đó n là kích thước của biểu tượng trong giao diện người dùng. Bạn phải chỉ định ít nhất một hình ảnh. Lưu ý rằng "details.path = foo" tương đương với "details.path = {'16': foo}"

    • tabId

      number không bắt buộc

      Giới hạn thay đổi khi một thẻ cụ thể được chọn. Tự động đặt lại khi thẻ bị đóng.

Giá trị trả về

  • Promise<void>

    Chrome 96 trở lên

setPopup()

chrome.action.setPopup(
  details: object,
)
: Promise<void>

Đặt tài liệu HTML sẽ mở ra dưới dạng cửa sổ bật lên khi người dùng nhấp vào biểu tượng của thao tác.

Thông số

  • chi tiết

    đối tượng

    • cửa sổ bật lên

      chuỗi

      Đường dẫn tương đối đến tệp HTML sẽ xuất hiện trong cửa sổ bật lên. Nếu bạn đặt thành chuỗi trống (''), thì sẽ không có cửa sổ bật lên nào xuất hiện.

    • tabId

      number không bắt buộc

      Giới hạn thay đổi khi một thẻ cụ thể được chọn. Tự động đặt lại khi thẻ bị đóng.

Giá trị trả về

  • Promise<void>

setTitle()

chrome.action.setTitle(
  details: object,
)
: Promise<void>

Đặt tiêu đề của thao tác. Thông tin này sẽ xuất hiện trong chú thích.

Thông số

  • chi tiết

    đối tượng

    • tabId

      number không bắt buộc

      Giới hạn thay đổi khi một thẻ cụ thể được chọn. Tự động đặt lại khi thẻ bị đóng.

    • tiêu đề

      chuỗi

      Chuỗi mà thao tác sẽ hiển thị khi di chuột qua.

Giá trị trả về

  • Promise<void>

Sự kiện

onClicked

chrome.action.onClicked.addListener(
  callback: function,
)

Được kích hoạt khi người dùng nhấp vào một biểu tượng thao tác. Sự kiện này sẽ không kích hoạt nếu thao tác có một cửa sổ bật lên.

Thông số

  • callback

    hàm

    Tham số callback có dạng như sau:

    (tab: tabs.Tab) => void

onUserSettingsChanged

Chrome 130 trở lên
chrome.action.onUserSettingsChanged.addListener(
  callback: function,
)

Được kích hoạt khi các chế độ cài đặt do người dùng chỉ định liên quan đến hành động của tiện ích thay đổi.

Thông số