userScripts 编辑
Use this API to register user scripts, third-party scripts designed to manipulate webpages or provide new features. Registering a user script instructs the browser to attach the script to pages that match the URL patterns specified during registration.
This API offers similar capabilities to contentScripts
but with features suited to handling third-party scripts:
- execution is in an isolated sandbox: each user script is run in an isolated sandbox within the web content processes, preventing accidental or deliberate interference among scripts.
- access to the
window
anddocument
global values related to the webpage the user script is attached to. - no access to WebExtension APIs or associated permissions granted to the extension: the API script, which inherits the extension’s permissions, can provide packaged WebExtension APIs to registered user scripts. An API script is declared in the extension's manifest file using the "user_scripts" manifest key.
This API requires the presence of the user_scripts
key in the manifest.json, even if no API script is specified. For example. user_scripts: {}
.
To use the API, call
passing in an object defining the scripts to register. The method returns a Promise that is resolved with a register()
object.RegisteredUserScript
User scripts are unregistered when the related extension page (from which the user scripts were registered) is unloaded, so you should register a user script from an extension page that persists at least as long as you want the user scripts to stay registered.
Types
userScripts.RegisteredUserScript
- The
object
returned by theregister()
method. It represents the registered user scripts and is used to deregister the user scripts.
Methods
userScripts.register()
- Registers user scripts.
Events
userScripts.onBeforeScript
- An event available to the API script, registered in
"user_scripts"
, that execute before a user script executes. Use it to trigger the export of the additional APIs provided by the API script, so they are available to the user script.
Browser compatibility
BCD tables only load in the browser
See also
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论