Ampli provides the benefits of type safety, linting, and data validation to make sure that your analytics are accurate and trustworthy.
To migrate from Amplitude SDK to Ampli, you need to replace all calls using Amplitude SDK with calls using Ampli. However, the process can be done gradually and at your own pace.
This page assumes you have existing analytics instrumentation using the Amplitude SDK.
1import * as amplitude from '@amplitude/analytics-browser'; 2 3amplitude.init(AMPLITUDE_API_KEY); 4amplitude.track('Song Played', { title: 'The best song in the world.' }); 5amplitude.track({ 6 event_type: 'Song Played', 7 event_properties: { 8 title: 'Song 2' 9 }10});11amplitude.flush();
It is easy to use Ampli with your existing Amplitude SDK implementation. Learn more about how Ampli and the Amplitude SDK work together in the Ampli overview documentation.
Start by passing your existing Amplitude SDK instance to Ampli. Ampli will use the given instance for all event tracking. This includes the API key, plugins, storage provider, log provider and other configuration set on the Amplitude instance.
1ampli.load({ client: { instance: amplitude }})
All existing amplitude.track('Song Played')
(a.k.a. amplitude.logEvent()
) will continue to work. However, you now also have access to strongly typed methods and types for all events for the Source in your tracking plan for exampleampli.songPlayed()
and ampli.track(new SongPlayed())
.
Amplitude recommends creating a branch and adding small sets of events at a time, which splits the migration into manageable parts rather than requiring all events to be implemented at once.
If you are planning to use ampli status
to verify instrumentation, all events for the current source must be implemented to pass. Isolating the instrumentation into small parts allows you to use ampli status
at each part of the migration versus waiting for all events to be completed.
ampli pull
to download the generated Events to your projectamplitude.track('My Event', {prop: true})
with ampli.myEvent({ prop: true})
or ampli.track(new MyEvent({prop:true}))
for each event in the tracking plan. 1import * as amplitude, { BaseEvent } from '@amplitude/analytics-browser'; 2+ import { ampli, SongPlayed } from './path/to/ampli'; 3 4// Original Implementation 5// Notice this will keep working as-is, so you can keep the 6// existing implementation while progressively migrating to Ampli 7 8amplitude.init(AMPLITUDE_API_KEY); 9amplitude.add(new MyPlugin());10amplitude.setUserId('me');11amplitude.track('Song Played', { title: 'Happy Birthday'});12amplitude.track({13 event_type: 'Song Played',14 event_properties: {15 title: 'The best song in the world.'16 }17});18amplitude.flush();19 20+ // Ampli implementation21+ // Pass in the existing instance of Amplitude SDK to Ampli22+ // Use Ampli to track new strongly typed methods and types23+ // All Ampli methods call the underlying Amplitude SDK instance24+25+ ampli.load({ client: { instance: amplitude }});26+ ampli.songPlayed({ title: 'Hello Sunshine' });27+ ampli.track(new SongPlayed({ title: 'Song 2' }));28+ ampli.flush();
After all existing Amplitude SDK instrumentation has been replaced with Ampli, you can do a little clean up by removing unnecessary imports and initialization of the Amplitude SDK and instead use the equivalent from Ampli. That’s it!
1- import * as amplitude, { BaseEvent, Options } from '@amplitude/analytics-browser'; 2+ import { ampli, SongPlayed, Options } from './path/to/ampli'; 3 4// Initialize 5const sdkOptions: Options = { ... }; 6- amplitude.init(AMPLITUDE_API_KEY, undefined, sdkOptions); 7+ ampli.load({ 8+ client: { 9+ apiKey: AMPLITUDE_API_KEY,10+ configuration: sdkOptions11+ }12+ })13 14// Plugins15- amplitude.add(new MyPlugin())16+ ampli.client.add(new MyPlugin())17 18// Set User19- amplitude.setUserId('me')20+ ampli.client.setUserId('me')21 22// Track Events23- amplitude.track('Song Played', { songId: 'Happy Birthday'});24+ ampli.songPlayed({title: 'Happy Birthday'});25+ ampli.track(new SongPlayed({ songId: 'The best song in the world.' }));26 27// Flush Events28- amplitude.flush();29+ ampli.flush();
1npm install @amplitude/analytics-browser
1npm install @amplitude/analytics-browser2npm install -g @amplitude/ampli3ampli pull [--path] ./ampli
ampli pull
requires a Source in Data. Without Events on the Source the user can still pull, but will only be able to use ampli.track()
without strongly typed events.
1import * as amplitude from '@amplitude/analytics-browser';2 3amplitude.init(AMPLITUDE_API_KEY);
1import { ampli, SongPlayed } from './ampli'; 2 3// Initialize with Amplitude API Key 4ampli.load({ 5 client: { 6 apiKey: AMPLITUDE_API_KEY 7 } 8}); 9 10// Or initialize with pre-existing Amplitude SDK instance11ampli.load({12 client: {13 instance: amplitude,14 }15});
1amplitude.track('Sign Up');2 3amplitude.track({4 event_type: 'Song Played',5 user_properties: {6 title: 'Get Back'7 }8})
1ampli.songPlayed({ title: "Get Back" }) 2ampli.track(new SongPlayed({ title: "Hey"})) 3 4// Not recommended, but possible 5// Ampli can track untyped events if desired 6ampli.track({ 7 event_type: 'Sign Up', 8 user_properties: { 9 userProp: 110 }11})
1amplitude.flush();
1ampli.flush();
1amplitude.setUserId('me'); 2amplitude.add(new MyPlugin()) 3amplitude.setGroup('team', 'awesome') 4amplitude.groupIdentify( 5 'team', 6 'awesome', 7 { 8 groupProperty: true 9 },10)
ampli.client
to access the underlying Amplitude SDK directly.
1ampli.client.setUserId('me'); 2ampli.client.add(new MyPlugin()) 3ampli.client.setGroup('team', 'awesome') 4ampli.client.groupIdentify( 5 'team', 6 'awesome', 7 { 8 groupProperty: true 9 },10)
Thanks for your feedback!
May 10th, 2024
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.