Scripts

Clarity by Microsoft is a screen recorder and heatmap tool that helps you understand how users interact with your website.

https://store-images.s-microsoft.com/image/apps.29332.512b1d3d-80ec-4aec-83bb-411008d2f7cd.76371b6f-9386-463f-bfb0-b75cffb86a4f.bd99f4b1-b18e-4380-aa79-93768763c90d.png
Clarity

View source

Nuxt Config Setup

Add this to your nuxt.config.ts to load Clarity globally. Alternatively you can use the useScriptClarity composable for more control.

export default defineNuxtConfig({
  scripts: {
    registry: {
      clarity: {
        id: 'xxxxxxxxxx',
        trigger: 'onNuxtReady',
      }
    }
  }
})

This config automatically enables first-party mode (bundle + proxy). See below to customise.

useScriptClarity()

The useScriptClarity composable lets you have fine-grain control over when and how Clarity is loaded on your site.

const { proxy } = useScriptClarity()

proxy.clarity('event', 'conversion')

Please follow the Registry Scripts guide to learn more about advanced usage.

First-Party Mode: Privacy Focused Proxy

No extra config needed. The script is bundled from your domain (faster loads, no extra DNS lookup) and runtime requests are reverse-proxied through your server with automatic anonymisation (user IPs stay hidden from Clarity, works with ad blockers). Learn more.

Mode
Bundle Proxy Partytown
Privacy
IP, language, and hardware fingerprints are anonymised. Screen dimensions pass through so heatmaps render accurately.
export default defineNuxtConfig({
  scripts: {
    // ✅ First-party mode: bundled + proxied
    registry: {
      clarity: {
        id: 'xxxxxxxxxx',
        trigger: 'onNuxtReady',
      },
    },
  },
})

Example

Using Clarity in a component with the proxy to send events .

<script setup lang="ts">
const { proxy } = useScriptClarity()

// noop in development, ssr
// just works in production, client
function handleAction() {
  proxy.clarity('event', 'conversion')
}
</script>

<template>
  <div>
    <button @click="handleAction">
      Send Event
    </button>
  </div>
</template>
idstring required

The Clarity token.