Skip to content

Latest commit

 

History

History
69 lines (50 loc) · 3.17 KB

README.md

File metadata and controls

69 lines (50 loc) · 3.17 KB

Chrome Extension Messaging API has awful documentation

The big offender is the one error message. Single. Error. Message.

Depending on the bug, Chrome either stays silence or displays:

Unchecked runtime.lastError: Could not establish connection. Receiving end does not exist.

Nothing specific. No line numbers.

So there's a heavy burden on the developer to internalize all the possible error cases of the API.

Time to get our hands dirty with some advanced use-cases.

Lessons

  • Prefer port.postMessage() over runtime.sendMessage()
    • runtime.sendMessage() says it's for "simple one-time request" – don't be seduced by the Dark Side
    • with ports, you have more control over the lifetime of the connection (the port won't get unexpectedly garbage collected as long as you hold a reference to it)
    • you can be notified when a port is disconnected
    • port names help avoid message crosstalk
    • you can't open and listen to the same port in the same frame (i.e. can't open a port with yourself), which helps prevent an anti-pattern of messaging overuse
    • if more than one listener is registered with the same port name, only the last listener registered handles the event
  • sendMessage() will call the response callback automatically (even if none is supplied) and pass in undefined
    • it's useful for auto-confirming that the message was received
    • but it's an unexpected pattern in Javascript
  • If using the response callback and an async function in sendMessage() receiver, then the message receiver function must return true
  • External page/app cannot listen for messages, only send
    • reasonable security design
  • Avoid race conditions by manually injecting the content script, instead of relying on the manifest file
    • this way, you're sure that the background script is ready

Resources


Install

  1. Run npm i
  2. Run npm start
  3. Open Chrome and go to chrome://extensions
  • Or click Settings > More Tools > Extensions
  1. Enable Developer Mode in Chrome
  2. Click-&-drag the crx/ directory into the Chrome Extensions page

This project was bootstrapped with Create React App.

Available Scripts

In the project directory, you can run:

npm start

Runs the app in the development mode.
Open http://localhost:3000 to view it in the browser.

The page will reload if you make edits.
You will also see any lint errors in the console.

npm test

Launches the test runner in the interactive watch mode.
See the section about running tests for more information.