Head
Nuxt Kit 提供了一些工具,帮助你在模块中管理 head 配置。
setGlobalHead
为你的 Nuxt 应用设置全局的 head 配置。该工具允许模块以编程方式配置 meta 标签、链接、脚本和其他 head 元素,这些配置会应用到所有页面。
提供的 head 配置会与现有的 head 配置进行深度合并,且你的配置项优先级更高。
这对于需要将全局 meta 标签、样式表或脚本注入应用 head 的模块尤其有用。
类型
import type { SerializableHead } from '@unhead/vue/types'
interface AppHeadMetaObject extends SerializableHead {
charset?: string
viewport?: string
}
function setGlobalHead (head: AppHeadMetaObject): void
参数
head
类型: AppHeadMetaObject
一个包含 head 配置的对象。所有属性均为可选,并会与已有配置合并:
charset:文档的字符编码viewport:视口 meta 标签配置meta:meta 标签对象数组link:link 标签对象数组(样式表、图标等)style:内联 style 标签对象数组script:script 标签对象数组noscript:noscript 标签对象数组title:默认页面标题titleTemplate:页面标题格式模板bodyAttrs:添加到<body>标签的属性htmlAttrs:添加到<html>标签的属性
示例
添加全局 Meta 标签
import { defineNuxtModule, setGlobalHead } from '@nuxt/kit'
export default defineNuxtModule({
setup () {
setGlobalHead({
meta: [
{ name: 'theme-color', content: '#ffffff' },
{ name: 'author', content: '你的名字' },
],
})
},
})
注入全局样式表
import { defineNuxtModule, setGlobalHead } from '@nuxt/kit'
export default defineNuxtModule({
setup () {
setGlobalHead({
link: [
{
rel: 'stylesheet',
href: 'https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap',
},
],
})
},
})
添加全局脚本
import { defineNuxtModule, setGlobalHead } from '@nuxt/kit'
export default defineNuxtModule({
setup () {
setGlobalHead({
script: [
{
src: 'https://cdn.example.com/analytics.js',
async: true,
defer: true,
},
],
})
},
})
设置 HTML 属性
import { defineNuxtModule, setGlobalHead } from '@nuxt/kit'
export default defineNuxtModule({
setup () {
setGlobalHead({
htmlAttrs: {
lang: 'en',
dir: 'ltr',
},
bodyAttrs: {
class: 'custom-body-class',
},
})
},
})