Scripts

TikTok Pixel

TikTok Pixel lets you measure, optimize and build audiences for your TikTok ad campaigns.

Nuxt Scripts provides a registry script composable useScriptTikTokPixel() to easily integrate TikTok Pixel in your Nuxt app.

Script Stats

Transfer
2.7 KB
Decoded
7.6 KB
Loading
Dynamic
First-Party
Supported
Bundling
Supported
Privacy
Full data collection
Tracked Data
Page Views Conversions Retargeting Audiences

Nuxt Config Setup

The simplest way to load TikTok Pixel globally in your Nuxt App is to use Nuxt config. Alternatively you can directly use the useScriptTikTokPixel composable.

export default defineNuxtConfig({
  scripts: {
    registry: {
      tiktokPixel: {
        id: 'CXXXXXXXXXXXXXX'
      }
    }
  }
})

useScriptTikTokPixel

The useScriptTikTokPixel composable lets you have fine-grain control over when and how TikTok Pixel is loaded on your site.

const { proxy } = useScriptTikTokPixel()

proxy.ttq.track('CompletePayment', { value: 1, currency: 'USD' })

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

First-Party Mode

This script supports First-Party Mode which routes all traffic through your domain for improved privacy and ad blocker bypass.

export default defineNuxtConfig({
  scripts: {
    firstParty: true,
    registry: {
      tiktokPixel: { id: 'CXXXXXXXXXXXXXX'}
    }
  }
})

To opt-out for this specific script:

useScriptTikTokPixel({
  id: 'CXXXXXXXXXXXXXX',
  scriptOptions: {
    firstParty: false
  }
})

Example

Using TikTok Pixel only in production while using the proxy to send events.

ConversionButton.vue
<script setup lang="ts">
const { proxy } = useScriptTikTokPixel()

// noop in development, ssr
// just works in production, client
function handleAction() {
  proxy.ttq.track('CompletePayment', { value: 1, currency: 'USD' })
}
</script>

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

TikTokPixelApi

export interface TikTokPixelApi {
  ttq: TtqFns & {
    push: TtqFns
    loaded: boolean
    queue: any[]
  }
}

type TtqFns =
  & ((cmd: 'track', event: StandardEvents | string, properties?: EventProperties) => void)
  & ((cmd: 'page') => void)
  & ((cmd: 'identify', properties: IdentifyProperties) => void)
  & ((cmd: string, ...args: any[]) => void)

type StandardEvents =
  | 'ViewContent' | 'ClickButton' | 'Search' | 'AddToWishlist'
  | 'AddToCart' | 'InitiateCheckout' | 'AddPaymentInfo' | 'CompletePayment'
  | 'PlaceAnOrder' | 'Contact' | 'Download' | 'SubmitForm'
  | 'CompleteRegistration' | 'Subscribe'

Config Schema

You must provide the options when setting up the script for the first time.

export const TikTokPixelOptions = object({
  id: string(),
  trackPageView: optional(boolean()), // default: true
})

Identifying Users

You can identify users for advanced matching:

const { proxy } = useScriptTikTokPixel()

proxy.ttq('identify', {
  email: '[email protected]',
  phone_number: '+1234567890'
})

Disabling Auto Page View

By default, TikTok Pixel tracks page views automatically. To disable:

export default defineNuxtConfig({
  scripts: {
    registry: {
      tiktokPixel: {
        id: 'YOUR_PIXEL_ID',
        trackPageView: false
      }
    }
  }
})