开发者工具栏应用 API
Astro 开发者工具栏应用 API 允许你创建可以用来扩展 Astro 开发者工具栏的应用。这使你可以添加新功能并与第三方服务集成。
添加应用
段落标题 添加应用Astro 集成 可以在 astro:config:setup
钩子 中使用 addDevToolbarApp
方法添加应用。
开发者工具栏应用的结构
段落标题 开发者工具栏应用的结构开发者工具栏应用是 .js
或 .ts
文件,默认情况下会导出具有以下必需属性的对象:
id: string
段落标题 id: string应用的唯一标识符。这将用于在钩子和事件中唯一的标识应用。
name: string
段落标题 name: string应用的名称。每当需要使用人类可读的名称引用应用时,都会向用户显示此名称。
icon: Icon
段落标题 icon: Icon应用的图标。这将用于在 UI 中显示应用。这可以是图标列表中的图标,也可以是包含图标 SVG 标记的字符串。
init: (canvas: ShadowRoot, eventTarget: EventTarget) => void
段落标题 init: (canvas: ShadowRoot, eventTarget: EventTarget) => void这是应用的核心部分。当加载应用时,将调用此函数,这将在浏览器空闲或用户在 UI 中点击应用时发生。
该函数接收两个参数:
canvas
段落标题 canvas应用可以用来渲染其 UI 的 ShadowRoot。每个应用都会收到自己的专用 ShadowRoot 来渲染其 UI。此外,父元素使用 position: absolute;
定位,因此,应用 UI 不会自动影响页面的布局。
eventTarget
段落标题 eventTarget可用于从开发者工具栏发送和接收事件的 EventTarget
。
beforeTogglingOff
段落标题 beforeTogglingOff当用户点击 UI 中的应用图标以关闭应用时,将调用此可选函数。例如,此函数可以用于执行清理操作,执行动画,或在关闭应用前要求用户确认。
如果返回 false
值,将取消关闭操作,应用将保持启用状态。
canvas
段落标题 canvas应用的 ShadowRoot,可以用来渲染任何需要的 UI。
客户端事件
段落标题 客户端事件使用 init
钩子上的 eventTarget
参数,应用可以从 Dev Toolbar 发送和接收事件。以下事件可用:
app-toggled
段落标题 app-toggled当用户在 Dev Toolbar 中点击应用图标时,会触发此事件。
placement-updated
段落标题 placement-updated当用户更改开发者工具栏的位置时,将触发此事件。
state: boolean
段落标题 state: boolean指示用户点击后应用是否启用。
toggle-notification
段落标题 toggle-notification可以发送此事件来通知用户该应用需要关注。
state: boolean
段落标题 state: boolean指示应用是否有针对用户的通知。当 true
时,应用图标将使用红点高亮显示。相反,当 false
时,将移除高亮。如果未指定此属性,将假定为 true
。
level: 'error' | 'warning' | 'info'
段落标题 level: 'error' | 'warning' | 'info'指示通知的级别。这将用于确定应用图标上高亮显示的颜色和形状(深粉色圆圈、金色三角形或蓝色正方形)。如果未指定此属性,将默认为 'error'
。
toggle-app
段落标题 toggle-app你的应用可以发送此事件来改变你的应用的状态。例如,这可以用于在你的应用的 UI 中实现 “关闭” 按钮。
state: boolean
段落标题 state: boolean指示应用是否应被启用。当 true
时,应用将被启用。相反,当 false
时,应用将被禁用。如果未指定此属性,将假定为 true
。
客户端 - 服务器通信
段落标题 客户端 - 服务器通信使用 Vite 的客户端 - 服务器通信方法,Dev Toolbar Apps 可以与服务器进行通信。
除了能够发送和接收自定义消息外,Dev Toolbar 还发送以下消息,其中 APP_ID
是应用的 ID:
astro-dev-toolbar:APP_ID:initialized
段落标题 astro-dev-toolbar:APP_ID:initialized当应用初始化时,会发送此消息。此消息的数据为空。
astro-dev-toolbar:APP_ID:toggled
段落标题 astro-dev-toolbar:APP_ID:toggled当用户在 UI 中点击应用图标时,会发送此消息。此消息的数据是布尔值,指示应用是否已启用。
Vite 的内置 connection
事件在 Dev Toolbar 应用初始化之前触发,因此应用不能直接使用它。相反,应使用 astro-dev-toolbar:APP_ID:initialized
事件。
UI 工具包
段落标题 UI 工具包Dev Toolbar 包含一套可以用来构建具有一致外观和感觉的应用的 web 组件。
astro-dev-toolbar-window
段落标题 astro-dev-toolbar-window显示窗口。
组件的插槽将被用作窗口的内容。
使用 JavaScript 构建窗口时,插槽内容必须放在组件的 light DOM 内。
astro-dev-toolbar-button
段落标题 astro-dev-toolbar-button显示按钮。
组件的插槽将被用作按钮的内容。
size
段落标题 size按钮的大小(small
,medium
,large
)。
button-style
段落标题 button-style按钮的样式(ghost
,outline
,purple
,gray
,red
,green
, yellow
, blue
)。当使用 ghost
时,按钮本身是不可见的,只会显示按钮的内容。
在 JavaScript 中,使用 buttonStyle
属性设置此属性以避免与原生 style
属性冲突。
astro-dev-toolbar-badge
段落标题 astro-dev-toolbar-badge显示徽章。
组件的插槽将被用作徽章的内容。
size
段落标题 size徽章的大小(small
,large
)。
badge-style
段落标题 badge-style徽章的样式(颜色)(purple
,gray
,red
,green
,yellow
,blue
)。
在 JavaScript 中,使用 badgeStyle
属性设置此属性以避免与原生 style
属性冲突。
astro-dev-toolbar-card
段落标题 astro-dev-toolbar-card显示一张卡片。指定可选的 link
属性使卡片像 <a>
元素一样行动。
当使用 JavaScript 制作卡片时,可以指定 clickAction
属性使卡片像 <button>
元素一样行动。
组件的插槽将被用作卡片的内容。
card-style
段落标题 card-style卡片的样式(purple
,gray
,red
,green
,yellow
,blue
)。这些颜色只会在鼠标悬停时应用于卡片的边框上。
在 JavaScript 中,使用 cardStyle
属性来设置这个属性。
astro-dev-toolbar-toggle
段落标题 astro-dev-toolbar-toggle显示切换元素,作为复选框。这个元素内部是简单的包装器,围绕着原生的 <input type="checkbox">
元素。可以使用 input
属性访问复选框元素。
toggle-style
段落标题 toggle-style切换的样式(purple
,gray
,red
,green
,yellow
,blue
)。
在 JavaScript 中,使用 toggleStyle
属性来设置这个属性。
astro-dev-toolbar-highlight
段落标题 astro-dev-toolbar-highlight可以用来高亮显示页面上的元素。在大多数情况下,你会想要使用 top
,left
,width
和 height
CSS 属性来定位和调整这个元素的大小,以匹配你想要高亮的元素。
style
段落标题 style高亮显示的样式(purple
,gray
,red
,green
,yellow
,blue
)。
icon
段落标题 icon用于在高亮显示的右上角展示的 图标。
astro-dev-toolbar-tooltip
段落标题 astro-dev-toolbar-tooltip显示带有不同 sections 的工具提示。此组件默认设置为 display: none;
,可以使用 data-show="true"
属性使其可见。
使用 sections
属性定义 sections。此属性是具有以下形状的对象的数组:
此组件通常与 astro-dev-toolbar-highlight
组件结合使用,当鼠标悬停在高亮的元素上时显示工具提示:
astro-dev-toolbar-icon
段落标题 astro-dev-toolbar-icon显示图标。可以使用 icon
属性指定图标列表中的图标,或者将图标的 SVG 标记作为插槽传递。
图标
段落标题 图标目前,可以在任何接受图标的组件中使用以下图标:
astro:logo
warning
arrow-down
bug
file-search
check-circle
gear
lightbulb
checkmark
dots-three
copy
以上所有图标默认设置为 fill="currentColor"
,并将从父元素继承其颜色。