Use Autocapture and Visual Labeling to Track Website Clicks
Simplify your Amplitude implementation and surface your product usage insights fast by learning how to use Autocapture and visual labeling to define your website click events.
Learn about Autocapture and Visual LabelingAmplitude's Autocapture is the best option for getting up and running quickly. This document helps you enable Autocapture across your digital products for out of the box analytics with minimal engineering.
Starting with version 2.10.0, the Amplitude Browser SDK includes Autocapture to help you capture events, interactions, and attribution on your site.
To get started with Autocapture, install the latest version of the Browser SDK (2.11.12) with the unified script loader, npm, or yarn.
<script src="https://cdn.amplitude.com/script/AMPLITUDE_API_KEY.js"></script>
<script>
  window.amplitude.init('AMPLITUDE_API_KEY', {
    fetchRemoteConfig: true,
    autocapture: true
  });
</script>
<script src="https://cdn.eu.amplitude.com/script/AMPLITUDE_API_KEY.js"></script>
<script>
  window.amplitude.init('AMPLITUDE_API_KEY', {
    serverZone: 'EU',
    fetchRemoteConfig: true,
    autocapture: true
  });
</script>
npm install @amplitude/analytics-browser
yarn add @amplitude/analytics-browser
Browser SDK 2.10.0 and above includes element click and change tracking, which enables visual labeling within Amplitude. To enable it, make sure config.autocapture.elementInteractions is set to true when initializing the SDK.
Autocapture ships with Browser SDK 2.10.0 and above. To enable it, set config.autocapture.elementInteractions to true when initializing the SDK.
import * as amplitude from '@amplitude/analytics-browser';
import { autocapturePlugin } from '@amplitude/plugin-autocapture-browser';
amplitude.init('AMPLITUDE_API_KEY', {
  autocapture: {
    elementInteractions: true,
    webVitals: true // Enable Core Web Vitals tracking
  }
});
If your web app configures the strict Content Security Policy (CSP) for security concerns, adjust the policy to allowlist to Amplitude domains:
https://*.amplitude.com to script-srchttps://*.amplitude.com to connect-src| Event | Description | Properties | 
|---|---|---|
| Page viewed | Captures when a user loads a page on your site. | Page counter, Page domain, Page location, Page path, Page title, Page URL, Session Replay ID (if enabled), Referrer, Attribution, User properties. | 
| Start session | Captures when a user starts a session on your site. | Session Replay ID (if enabled), User properties. | 
| End session | Captures when a user ends a session on your site. | User properties. | 
| Form started | Captures when a user interacts with a form on your site. | Form destination, Session Replay ID (if enabled), User properties. | 
| Form submitted | Captures when a user submits a form on your site. | Form destination, Session Replay ID (if enabled), User properties. | 
| File downloaded | Captures when a user downloads a file from your site. | File extension, File name, Link text, Link URL, Session Replay ID (if enabled), | 
| Element clicked | Captures when a user clicks an element on the page. | Element Aria Label, Element Class, Element Hierarchy, Element Href, Element ID, Element Parent Label, Element Position Left, Element Position Top, Element Selector, Element Tag, Element Text, Page Title, Page URL, Session Replay ID, Viewport Height, Viewport Width. | 
| Element changed | Captures form element interactions, such as changes a dropdown or inputs text into a text box. | Element Class, Element Hierarchy, Element ID, Element Parent Label, Element Position Left, Element Position Top, Element Tag, Page Title, Page URL, Session Replay ID, Viewport Height, Viewport Width. | 
| Network request | Captures when the application makes a network request. | URL, Request method, Status code, Duration, Request body size, Response body size, Session Replay ID (if enabled). | 
| Web vitals | Captures Core Web Vitals performance metrics when the browser tab becomes hidden. | Page domain, Page location, Page path, Page title, Page URL, LCP, FCP, INP, CLS, TTFB metrics with performance ratings and timing data. | 
For more information, see Autocapture in the Browser SDK 2 documentation.
Captures the following properties:
utm_source, utm_medium, utm_campaign, utm_term, utm_content)referrer, referring_domain)Amplitude attaches User Properties to all Autocapture events, unless disabled.
Amplitude's visual labeling tool enables you to identify and select individual elements on a page that you want to track. For example, if you want to track the number of users who click a Sign up, button you can select it with visual labeling, and Amplitude creates an event that targets the specific element.
Events you add with visual labeling work retroactively, since Amplitude captures all form-related events starting from when your instrumentation is live.
For more information, see Visual labeling.
The latest version of Amplitude's iOS SDK includes Autocapture capabilities.
Install the SDK as instructed in the iOS-Swift SDK documentation.
The iOS SDK enables session tracking, and disables application lifecycle, screen view, and element interaction tracking by default. To enable all Autocapture capabilities, initialize the SDK with the following snippet:
let amplitude = Amplitude(configuration: Configuration(
    apiKey: "API_KEY",
    autocapture: [.sessions, .appLifecycles, .screenViews, .networkTracking] 
))
AMPConfiguration* configuration = [AMPConfiguration initWithApiKey:@"API_KEY"];
configuration.autocapture = [[AMPAutocaptureOptions alloc] initWithOptionsToUnion:@[  
    AMPAutocaptureOptions.sessions,  
    AMPAutocaptureOptions.appLifecycles,  
    AMPAutocaptureOptions.screenViews,  
    AMPAutocaptureOptions.networkTracking  
]]; 
Amplitude* amplitude = [Amplitude initWithConfiguration:configuration];
| Event | Description | Properties | 
|---|---|---|
| Start session | Captures when a user starts a session in your app. | User properties. | 
| End session | Captures when a user ends a session in your app. | User properties. | 
| Application installed | Captures when a user opens the app for the first time after they install it. | |
| Application updated | Captures when a user opens the app for the first time after they update it. | |
| Application opened | Captures when a user launches or foregrounds the app after the first open. | |
| Application backgrounded | Captures when a user backgrounds the application. | |
| Screen viewed | Captures when a user views a screen in your app. | Screen name | 
| Element Interacted | Captures when a user interacts with the UI elements in your app. | Element properties | 
| Network request | Captures when a the app makes a network request. | URL, request method, status code, etc. | 
Amplitude attaches User Properties to all Autocapture events, unless disabled.
The latest version of Amplitude's Android SDK includes Autocapture capabilities.
Install the SDK as instructed in the Android-Kotlin SDK documentation.
The Android-Kotlin SDK enables session tracking, and disables application lifecycle, screen view, deep link, and element interaction tracking by default. To enable all Autocapture capabilities, initialize the SDK with the following snippet:
Amplitude(
	Configuration(
	 apiKey = AMPLITUDE_API_KEY,
		context = applicationContext,
		autocapture = autocaptureOptions { 
          +sessions               // or `+Autocapture.SESSIONS` [tl! ~~]
          +appLifecycles          // or `+Autocapture.APP_LIFECYCLES` [tl! ~~]
          +deepLinks              // or `+Autocapture.DEEP_LINKS` [tl! ~~]
          +screenViews            // or `+Autocapture.SCREEN_VIEWS` [tl! ~~]
    	} 
	)
)
Configuration configuration = new Configuration(AMPLITUDE_API_KEY, getApplicationContext());
configuration.getAutocapture().addAll(Arrays.asList( 
    AutocaptureOption.APP_LIFECYCLES, 
    AutocaptureOption.DEEP_LINKS, 
    AutocaptureOption.SCREEN_VIEWS
)); 
Amplitude amplitude = new Amplitude(configuration);
| Event | Description | Properties | 
|---|---|---|
| Start session | Captures when a user starts a session in your app. | User properties. | 
| End session | Captures when a user ends a session in your app. | User properties. | 
| Application installed | Captures when a user opens the app for the first time after they install it. | |
| Application updated | Captures when a user opens the app for the first time after they update it. | |
| Application opened | Captures when a user launches or foregrounds the app after the first open. | |
| Application backgrounded | Captures when a user backgrounds the application. | |
| Screen viewed | Captures when a user views a screen in your app. | Screen name | 
| Deep link opened | Captures when a user opens a deep link in your app. | URL and referrer information | 
| Element Interacted | Captures when a user interacts with the UI elements in your app. | Element properties | 
Amplitude attaches User Properties to all Autocapture event, unless disabled.
March 20th, 2025
Need help? Contact Support
Visit Amplitude.com
Have a look at the Amplitude Blog
Learn more at Amplitude Academy
© 2025 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.