Written by Giancarlo Buomprisco. Published originally on "Bits and Pieces"
A detailed overview of the current state of Angular, from the latest features to the hottest topics and trends that you may have missed
It’s that time of the year when conferences and events are happening all over the world and we are bombarded with an amount of information that is pretty hard to digest.
The Front End world is a never-stopping machine and we all know how hard it is not to stay behind. Watching all the conferences takes a lot of time, and quite understandably, most of us may prefer Netflix after a day at the office!
For these reasons, I want to help you decompress the information overload and give you an overview of the state of Angular in 2019 in a single post.
This is what we’re going to talk about in this article:
The current state of Angular
The latest features of the Framework
The latest topics and trends
Understanding some of the words you may see here and there but that you’re not actually very clear about (yet)
Tip: Use Bit (Github) to easily share and reuse Angular components across your projects, suggest updates, sync changes and build faster as a team.
Components with Bit: Easily share across projects as a team
Angular’s adoption is growing
According to the stats provided by the Angular’s current Engineering Manager Brad Green at ng-conf 2019, since last year Angular’s adoption has increased by about 50%!
It is undeniable that these stats may be inflated by the number of projects that are in the process of being upgraded from the older Angular 1.X, and yet that’s impressive growth.
Angular is not as fast-growing as Svelte or Vue and not as widely used as React, but opposite of what you’re likely reading on Reddit and Twitter, Angular is in a healthy state and is used by millions of developers and teams.
The Angular’s Ecosystem is large and thriving
Even if the framework is shipped with an incredible amount of tooling out of the box provided by the Angular team itself, the ecosystem provided by the community is incredibly large and high-quality.
We have all sorts of things that we can use with Angular:
Deep integration with awesome fast-growing tools such as Typescript and RxJS, which make Angular benefit indirectly as these tools make more and more progress
State management libraries of different flavors
Code Quality toolings, such as Codelyzer
UI libraries, Components, Directives, Pipes, etc.
Large IDE plugins repositories
Testing Frameworks and utility libraries
Last but not least, extensive documentation from both the community and the Angular team in regards to best practices, guides, tutorials, books, video-courses, etc.
In the next paragraphs, we will see a detailed overview of some of the best tools we can use in our Angular projects.
The deep integration with tools such as Typescript and RxJS *make Angular benefit indirectly* as these tools make more and more progress
Angular CLI
Updating is easier than ever
… and here’s proof
As neatly described by Mart Ganzevles, the BlueWeb project that server half a billion users every year has been upgraded from version 7 to version 8 in a day of work, compared to 30 days when upgrading from version 2 to version 4.
This is further proof of how great a tool the Angular CLI, which can boost our productivity to levels I had personally never experienced before.
It’s become quite difficult to imagine working without it nowadays.
Schematics
Angular Schematics are a feature you probably are using every day. For instance, I’m sure you use ng generate component my-component a lot. Yeah, that’s a schematic that is bundled with the CLI.
What you may not know, though, is that you could increase your productivity by creating your own schematics for pieces of code you repeat often.
Builders
Builders allow you to extend or augment existing commands. For example, you could create a builder to execute your tests with Jest and Cypress rather than Jasmine and Protractor or use a different Linter.
New and Exciting Features
At the time of writing, Angular recently shipped version 8 with various improvements and features.
Nothing that deeply affects how we use the framework, which most of the times is good news, but under-the-hood improvements that make Angular’s projects smaller and faster, improve the already awesome Developer Experience with the using the framework, and the almost-complete new renderer.
Differential Loading
The concept of differential loading is easier than its name would suggest. Simply put, the compiler will generate two bundles: one for browsers with modern capabilities stripped out of the polyfills needed, and one for older browsers.
The newest browsers will load the modern bundles, the older ones that need the polyfills will load the legacy bundles.
This is a big win, as most users are likely using the latest browsers, so w*e only ship the legacy browsers to a small subset of our users*!
Web Workers
You probably have heard of Web Workers already so we’ll skip the whole introduction thing. What you may not be aware of though is how easy it has become to integrate your Web Workers with Angular thanks to its newest release. Take a look at the documentation!
CDK
The CDK is a set of tools released by the Angular Components team. They provide abstractions used by Angular Material but they are agnostic in regards to styling.
For example, you could use directives such as:
Drag and Drop
Auto-resizable text area
Overlay for your popups
Virtual Scrolling
The CDK is exceptionally useful as most apps could use well-done commonly used functionalities without having to use full, bloated, ad-hoc components. Angular Material is great, but you could implement your own components just by using the building blocks provided by the CDK.
Ivy Renderer
Ivy is an extremely exciting new in-progress development that will be shipped as the third renderer for Angular. It’s not quite here yet as it is not enabled by default, but you can opt-in and use it in your project since version 7. It will be shipped by default with Angular version 9.
What can you expect from Ivy?
Smaller bundles
Debuggable templates
Faster builds, faster tests
Lots of bugs fixed
Here’s a screenshot when I place a breakpoint in the Chrome console:
As you can see, the ngForOf directive gives us information about what’s being passed as value.
Angular on Mobile
Ionic
Ionic is a framework for building mobile applications. While the core components are written using Stencil, they provide abstractions you can use with Angular (and other frameworks).
NativeScript
NativeScript a React Native-like framework for building native mobile applications. Although they also provide support for Vue and plain Javascript, it offers deep integration with Angular. Unfortunately, my experience with it was not awesome and I don’t personally put it on the same level as React Native, but you should give it a try if mobile is your thing.
Testing
Jasmine & Protractor
Although they need no introduction, Jasmine and Protractors and the testing frameworks shipped by default with Angular. They’re battle-tested, updated and work amazingly with Angular.
Jest & Cypress
Testing Angular with Jest and Cypress has become possible thanks to the new custom Builders provided with the Angular CLI.
Jest is a unit-testing framework based on Jasmine, developed at Facebook. It is the de-facto framework for testing React projects and it is widely appreciated for its speed. Many folks prefer it to Jasmine in overall, so if that’s you, you can now use it!
Cypress is a highly regarded E2E testing framework and is getting a lot of love all around, and for good reasons. It is not dependent on Selenium or Webdriver, allows for time traveling through a commands log, allows for network traffic control, and promises more consistent results that don’t randomly fail.
Angular Testing Library
Angular Testing Library is a set of utilities to test UI components in a user-centric way.
That means this library encourages you to never use your components programmatically and test the behavior by doing actions your users would do.
For instance, you won’t use:
myComponent.onClick();
But instead, you’ll simulate the click as a user would naturally do:
const { getByText, click } = await render(CounterComponent, {
componentProperties: { counter: 5 }
});
click(getByText('+'));
State Management
NgRx
NgRx is a Redux-inspired state management library and likely the most used in the Angular community. As the name suggests, it is heavily reliant on RxJS streams.
NGXS
NGXS is an alternative library that also brings Redux-like state management to Angular. Compared to NgRx, NGXS makes heavy use of classes and decorators in order to reduce the boilerplate, and this aspect may be the most important one for choosing one between the two if classes are your thing.
Akita
Akita is a state management library provided by the company Datorama also based on RxJS, and compared to the previous two it can be also used for non-Angular projects, which can make your code more reusable in the long run.
Just… RxJS?
Yes! Depending on whether you like Redux libraries or whether your projects needs a state-management library at all, you may as well build services that store state with RxJS Subjects!
UI Component Libraries
Storybook
StoryBook is not a UI Component library but a tool that allows you to build components in isolation and gives us an easy way to explore all the components and their variations.
It’s an awesome tool for which I envied React developers for a long time, but we can now use it and it’s hard not to recommend using it.
Angular Material
The infamous Angular Material is back at it and brings an even more beautiful set of components for the newest version of Angular.
Backends for Angular
Firebase
Firebase is an application development platform owned by Google and, as a result, ships a first-class library Angular Fire that uses the power of RxJS Observables for streaming data, making the integration with Angular deep and seamless.
GraphQL
You may think that only the React community has the pleasure of working with GraphQL… and you may be wrong. The Apollo library is also available for Angular and provides an awesome alternative to Firebase if you prefer working with GraphQL.
NestJs
NestJS is a Node Web Framework for building server applications, and as you may see from the examples, is deeply inspired by Angular’s core concepts, such as Modules, Controllers, Pipes, etc. If you like Angular, then you’ll probably like NestJS too.
If you use Nx Workspaces, setting up a full-stack application with Angular and NestJS is only one command away!
Final Words
In summary, Angular has an incredibly high-quality and rich ecosystem.
Of course, I could not mention dozens of libraries and tools that I admire, otherwise, this post would have been endless. But I hope this article can give you an overview of the current state of Angular and the potentialities that could potentially power your next project.
If you need any clarifications, or if you think something is unclear or wrong, please leave a comment!
If you enjoyed this article, follow me on *Medium* or *Twitter for more articles about Angular, RxJS, Typescript and more!*
Top comments (7)
That's how i felt after reading the title
but then i read the text, and i must say... you did a great job here! thanks to it!
Thank you :)
We've just been afraid to adopt it because Google has a history of abandoning projects.
Morale of the story: NEVER break backward compatibility.
I would have chosen it over React for several projects (I help companies make those decisions), but when projects show a willingness to break compatibility it sends shivers down people's spines.
Maybe the fear is unfounded.. but its there nevertheless.
I wish we lived in a world were technical merit was the only factor.
You're definitely not wrong to have this feeling. Heck, I think most people that adopted AngularJS back in the day are still feeling this.
However, I think Google has made it abundantly clear that Angular is here to stay. It's in use on hundreds of internal applications at Google and they have LTS versions.
I can't comment on other Google projects with such certainty, but I don't believe there's any fear of support for Angular suddenly (or even slowly) disappearing.
Actually, they use it for about 1500 as of August :)
Google uses Angular for about 1500 projects. If they abandoned it, they'd be the first ones in trouble.
Angular.js was an ageing framework that no longer had the capability to work for modern applications.
Nice post. Thanks for sharing.