Migrating to Aurelia 2
Aurelia 2 is a complete rewrite of Aurelia that shares many of the same loved and familiar features of Aurelia 1. Understandably, in the spirit of progress, not everything is the same. In this section, we are going to guide you through what has changed and how you can migrate over your Aurelia 1 applications to Aurelia 2.
COMPAT PACKAGE
An quickest way to get an application in v1 up an running in v2 is to include the compat package. It can be done via 2 steps:
installing the compat package via
npm install @aurelia/compat-v1include the compat package into your app:
import { compatRegistration } from '@aurelia/compat-v1';
...
Aurelia
.register(compatRegistration, ...)
.app(...)
.start()BREAKING CHANGES
Scope selection
In v2, when trying to bind with a non-existent property, the closest boundary scope will be selected, instead of the immediate scope of the binding (v1 behavior).
Internal binding property observeProperty has been renamed to observe
observeProperty has been renamed to observeIn v1, if you happen to use .observeProperty method from bindings in your application/library, then change it to observe instead. The parameters of the signature remain the same.
Internal binding property sourceExpression has been renamed to ast
sourceExpression has been renamed to astIn v1, if you happen to use .sourceExpression property from bindings in your application/library, then change it to ast instead. The type of the property remains the same.
Enhance API changes:
In v1, enhance method on an Aurelia instance has the signature:
In v2, enhance method on an Aurelia instance has the signature:
Parent container and resources can be specified through this config.
Call binding (some-prop.call="...")
The call binding no longer assigns properties of the first argument pass to the call to the calling override context. This is unreasonably dynamic and could result in hard-to-understand templates.
In Aurelia 1, you would have used call bindings like this:
In Aurelia 2, the property name is now on the $event property passed to the callback. It's a minor change, but you now do this instead:
If attribute (if.bind="...")
The primary property of
Ifhas been renamed fromconditiontovalue. If you are usingif.bind, you are not affected. If you are using the multi prop binding syntax, the template looks like this:
Change it to:
Binding Engine
BindingEnginehas been removed in v2, but can still be imported from@aurelia/compat-v1package for ease of migration. ThecollectionObservermethod on the compat package ofBindingEngineis not the same with v1, per the follow comparison: v2v1
Binding commands
.delegatecommand has been removed, use.triggerinstead. With shadow DOM, even though.delegateworks, it doesn't feel as natural as.trigger, and the performance benefits.delegatecommand used to give when browsers were slow adding many event listeners is no longer as big..callcommand has been removed, use lambda functions instead to create function that preserves thethiscontext. Refer to lambda expression
Compose
<compose>has been renamed to<au-compose>. The bindable properties of this component have also been changed:viewModel -> component
view -> template
model remains the same
Examples migration fix:
Read more about dynamic composition in v2 in this dynamic composition doc and dynamic ui composition doc.
General changes
Templates no longer need to have
<template>tags as the start and ending tags. Templates can be pure HTML with enhanced Aurelia markup but<template>doesn't need to be explicitly defined.PLATFORM.moduleNameis gone. This was to address a limitation in Aurelia 1. Aurelia 2 now works well with all bundlers and does not require the addition of this code to use code splitting or tell the bundler where template code is.Better intellisense support for TypeScript applications. Using the new injection interfaces, you can now inject strongly typed Aurelia packages such as Fetch Client, Router or Internationalization. These packages are prefixed with an "I" such as
IHttpClient,IRouterand so on.
Plugins:
Web-Components plugin
Remove automatic au- prefix
Remove auto-conversion of Aurelia element -> WC element. Applications need to explicitly define this. This should make mix-matching & controlling things easier.
Last updated
Was this helpful?