Unhead v3 removes all deprecated APIs and focuses on performance improvements. This guide covers the breaking changes.
🚦 Impact Level: High
The DeprecationsPlugin that automatically converted legacy property names has been removed. You must update your head entries to use the current property names.
children → innerHTML
useHead({
script: [{
- children: 'console.log("hello")',
+ innerHTML: 'console.log("hello")',
}]
})
hid / vmid → key
useHead({
meta: [{
- hid: 'description',
+ key: 'description',
name: 'description',
content: 'My description'
}]
})
body: true → tagPosition: 'bodyClose'
useHead({
script: [{
src: '/script.js',
- body: true,
+ tagPosition: 'bodyClose',
}]
})
🚦 Impact Level: High
The PluginSchemaOrg and SchemaOrgUnheadPlugin exports have been removed. Use UnheadSchemaOrg instead.
- import { PluginSchemaOrg } from '@unhead/schema-org'
+ import { UnheadSchemaOrg } from '@unhead/schema-org'
const head = createHead({
plugins: [
- PluginSchemaOrg()
+ UnheadSchemaOrg()
]
})
🚦 Impact Level: Medium-High
The useServerHead, useServerHeadSafe, and useServerSeoMeta composables have been removed. Use the standard composables instead.
- import { useServerHead, useServerSeoMeta } from 'unhead'
+ import { useHead, useSeoMeta } from 'unhead'
- useServerHead({ title: 'My Page' })
+ useHead({ title: 'My Page' })
- useServerSeoMeta({ description: 'My description' })
+ useSeoMeta({ description: 'My description' })
If you need server-only head management, use conditional logic:
if (import.meta.server) {
useHead({ title: 'Server Only' })
}
🚦 Impact Level: Medium
createHeadCore → createUnhead
- import { createHeadCore } from 'unhead'
+ import { createUnhead } from 'unhead'
- const head = createHeadCore()
+ const head = createUnhead()
headEntries() → entries Map
- const entries = head.headEntries()
+ const entries = [...head.entries.values()]
mode Option Removed
The mode option on head entries has been removed.
head.push({
title: 'My Page',
- }, { mode: 'server' })
+ })
🚦 Impact Level: Low
The following hooks have been removed:
init - No longer neededdom:renderTag - DOM rendering is now synchronousdom:rendered - Use code after renderDOMHead() insteadThe dom:beforeRender hook is now synchronous and renderDOMHead no longer returns a Promise:
- await renderDOMHead(head, { document })
+ renderDOMHead(head, { document })
The SSR hooks (ssr:beforeRender, ssr:render, ssr:rendered) are now synchronous and renderSSRHead no longer returns a Promise:
- const head = await renderSSRHead(head)
+ const head = renderSSRHead(head)
🚦 Impact Level: Low
| Removed Type | Replacement |
|---|---|
Head | HeadTag or specific tag types |
ResolvedHead | ResolvedHeadTag |
MetaFlatInput | MetaFlat |
RuntimeMode | Removed (no replacement needed) |
- import type { Head, MetaFlatInput, RuntimeMode } from 'unhead'
+ import type { HeadTag, MetaFlat } from 'unhead'
resolveScriptKey - Internal utility, no longer exportedDeprecationsPlugin - Update property names directly insteadextractUnheadInputFromHtml - Use parseHtmlForUnheadExtraction from unhead/parserWith the release of Unhead v2, we now have first-class support for other frameworks. This section covers the v1 to v2 migration.
🚦 Impact Level: Critical
⚠️ Breaking Changes:
createServerHead() and createHead() exports from unhead are removedThe path where you import createHead from has been updated to be a subpath export.
Client bundle:
-import { createServerHead } from 'unhead'
+import { createHead } from 'unhead/client'
// avoids bundling server plugins
createHead()
Server bundle:
-import { createServerHead } from 'unhead'
+import { createHead } from 'unhead/server'
// avoids bundling server plugins
-createServerHead()
+createHead()
🚦 Impact Level: Critical
⚠️ Breaking Changes:
getActiveHead(), activeHead exports are removedThe implicit context implementation kept a global instance of Unhead available so that you could use the useHead() composables anywhere in your application.
In v2, the core composables no longer have access to the Unhead instance. Instead, you must pass the Unhead instance to the composables.
unhead. In JavaScript frameworks we tie the context to the framework itself so you don't need to worry about this.import { useHead } from 'unhead'
// example of getting the instance
const unheadInstance = useMyApp().unhead
useHead(unheadInstance, {
title: 'Looks good'
})
vmid, hid, children, body🚦 Impact Level: High
For legacy support with Vue Meta we allowed end users to provide deprecated properties: vmid, hid, children and body.
You must update these properties to the appropriate replacement or remove them. See the v3 migration section for the replacements.
🚦 Impact Level: High
To reduce the bundle size and improve performance, we've moved the template params and tag alias sorting to optional plugins.
import { AliasSortingPlugin, TemplateParamsPlugin } from 'unhead/plugins'
createHead({
plugins: [TemplateParamsPlugin, AliasSortingPlugin]
})
🚦 Impact Level: Medium
If you have promises as input they will no longer be resolved, either await the promise before passing it along or register the optional promises plugin.
import { PromisePlugin } from 'unhead/plugins'
const unhead = createHead({
plugins: [PromisePlugin]
})
useScript()🚦 Impact Level: High
⚠️ Breaking Changes:
script.proxy is rewritten for simpler, more stable behaviorstub() and runtime hook script:instance-fn are removedReplacing promise usage
const script = useScript()
-script.then(() => console.log('loaded')
+script.onLoaded(() => console.log('loaded'))
Replacing proxy usage
const script = useScript('..', {
use() { return { foo: [] } }
})
-script.foo.push('bar')
+script.proxy.foo.push('bar')
🚦 Impact Level: Low
Capo.js sorting is now the default. You can opt-out:
createHead({
disableCapoSorting: true,
})
🚦 Impact Level: Low
When SSR Unhead will now insert important default tags for you:
<meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1"><html lang="en">import { createHead } from 'unhead/server'
// disable when creating the head instance
const head = createHead({
disableDefaults: true,
})
🚦 Impact Level: Low
CommonJS exports have been removed in favor of ESM only.
-const { createHead } = require('unhead/client')
+import { createHead } from 'unhead/client'
@unhead/schema🚦 Impact Level: Low
The @unhead/schema package is deprecated. Import from unhead/types or unhead instead.
-import { HeadTag } from '@unhead/schema'
+import { HeadTag } from 'unhead/types'