Meta Pixel
Last updated May 11, 2026
Meta Pixel (formerly Facebook Pixel) is Meta's conversion tracking and audience targeting tool for Facebook and Instagram advertising. It tracks user actions, measures ad effectiveness, builds custom audiences, and optimizes ad delivery.
Integrate with c15t
How c15t loads it
- Category:
marketing(Ads & Pixels) - Loads when: marketing consent is granted
- Default install: c15t queues
fbq('consent', 'grant'),fbq('init', pixelId),fbq('track', 'PageView'), then loads Meta'sfbevents.js - On revocation: persists — c15t calls
fbq('consent', 'revoke')so Meta stops tracking without removing the script
Meta recommends installing the base pixel on every page you want to measure. c15t injects scripts into the document head by default, which matches Meta's recommendation to load the pixel early.
Configure the integration
Use the default setup when you want Meta's standard PageView event to fire as soon as the pixel loads after marketing consent.
For single-page applications, disable the automatic PageView and track route changes yourself.
You can pass optional init data as the third argument to fbq('init', ...).
Tracking events in your app
c15t gates the Meta Pixel script from loading until marketing consent is
granted. After consent is granted the script stays in the DOM, and c15t calls
fbq('consent', 'revoke') if consent is later revoked so Meta stops tracking
without removing the script.
This means window.fbq and the metaPixelEvent helpers are only defined after
the user has granted marketing consent at least once. Before that, unguarded
calls throw.
Standard events
Use metaPixelEvent to track Meta standard events. It is a typed wrapper around fbq('track', ...).
Meta documents standard event tracking in its conversion tracking guide and Marketing API pixel examples.
The optional third argument can be an event ID string or an options object. c15t forwards string IDs as { eventID: '...' }, which is the browser-side format used for Conversions API deduplication.
Custom events
Use metaPixelCustomEvent when Meta's standard events do not fit the action you are measuring. Meta custom event names must be strings and cannot exceed 50 characters.
Custom events can also use an event ID for Conversions API deduplication.
Guard event calls with consent
The example below intentionally uses useConsentManager().has('marketing') as
a defensive policy so your app avoids calling metaPixelEvent whenever consent
is currently revoked, even though Meta also suppresses tracking after initial
load.
SPA route changes
Meta's SPA guidance recommends tracking meaningful URL changes from your router. Disable the install-time PageView, then emit page views after navigation while marketing consent is granted.
Consent and privacy
Meta's GDPR guidance documents fbq('consent', 'revoke') and fbq('consent', 'grant'). c15t handles those calls for you after the script has loaded once:
- Before marketing consent, c15t does not load Meta Pixel.
- When marketing consent is granted, c15t loads Meta Pixel and calls
fbq('consent', 'grant'). - When marketing consent is revoked later, c15t keeps the script in place and calls
fbq('consent', 'revoke').
For US state privacy rules, Meta supports Data Processing Options. Pass dataProcessingOptions to queue fbq('dataProcessingOptions', ...) before fbq('init', ...).
Let Meta geolocate Limited Data Use:
Enable Limited Data Use for California:
Explicitly disable Limited Data Use:
Catalog and collaborative ads
For Advantage+ catalog ads, Meta requires ViewContent, AddToCart, and Purchase events to include either content_ids or contents. IDs must match your product catalog. See Meta's Advantage+ catalog ads guide.
For collaborative ads, Meta requires content_type: 'product'; AddToCart and Purchase also require contents, currency, and value. See Meta's collaborative ads pixel guide.
Movies
Meta's movies pixel guide uses the standard events ViewContent, InitiateCheckout, Purchase, and PageView with movie-specific parameters such as movieref.
Multiple pixels
Meta's multiple pixel guidance warns that fbq('track', ...) and fbq('trackCustom', ...) fire for every initialized pixel ID. If another integration or tag manager initializes more than one pixel, use the single-pixel helpers to prevent overfiring.
Custom audiences and sharing
Meta custom audiences are configured in Events Manager after standard events, custom events, or custom conversions are being received. The c15t integration sends the browser events; audience rules are managed in Meta. See Meta's custom audiences guide.
Pixel sharing between businesses or agencies is also managed through Meta Business Manager or the Business Management APIs, not through the browser script. See Meta's pixel sharing guide.