What is Lightning Web Component?
It's new programming model built on the modern web standards. LWC is the Salesforce implementation of that new breed of lightweight frameworks built on web standards.
It leverages custom elements, templates, shadow DOM, decorators, modules, and other new language constructs available in ECMAScript 7 and beyond.
Lightning Web Components provides a layer of specialized Salesforce services on top of the core stack, including base lightning components,Lightning Data Service and User Interface API.
Before we understand more about lightning web components we have to know about ECMA.
ECMA is an organization which develops standards for web technologies. They provide the specification for new features which has to implement in web technologies (HTML, CSS, javascript).
ECMA - European Computer Manufacturer’s Association.
Journey of Web Stack Transformation from 2014 to 2019
In 2014 when aura framework was launched.At that time Web Standards had limited functionality and various framework came to fulfil the gaps like ReactJS,CommonJS,AngularJS etc.
But something very different happened to web browsers in the four years since the introduction of Aura.Google began to champion a new concept known as Web Components to the internet community. The idea was to scrap the decades-old limitations of what web browsers were capable of and agree to a new set of standards that would be more flexible and powerful to web developers.
Why LWC actual come in picture after 2014?
Web Components was released to Google’s Chrome browser in 2014 and then it made its way through various committees within the tech community.
After some revisions and feedback from other companies such as Salesforce, the specifics were ultimately agreed upon and implemented.
LWC are able to utilize the new standards while still having the ability to access Salesforce data and work within the existing Lightning Experience UI.
This results in faster speeds and processing of Salesforce applications because the web browser has a more direct access to the processing capability of your computer. Salesforce can now focus their resources on Salesforce-specific functionality and not just creating a webpage for you.
4 Pillars of Web Component :
LWC = HTML (UI Interface) + JavaScript (to handle events) + CSS + meta XML file(target where to place the component eg:lightning__AppPage/lightning__RecordPage/lightning__HomePage)
Coexistence and Interoperability of LWC and Aura Component
1.Aura Components, leveraging its own component model, templates, and modular development programming model.
It's new programming model built on the modern web standards. LWC is the Salesforce implementation of that new breed of lightweight frameworks built on web standards.
It leverages custom elements, templates, shadow DOM, decorators, modules, and other new language constructs available in ECMAScript 7 and beyond.
Lightning Web Components provides a layer of specialized Salesforce services on top of the core stack, including base lightning components,Lightning Data Service and User Interface API.
Before we understand more about lightning web components we have to know about ECMA.
ECMA is an organization which develops standards for web technologies. They provide the specification for new features which has to implement in web technologies (HTML, CSS, javascript).
ECMA - European Computer Manufacturer’s Association.
- ECMAScript is a Standard for a scripting languages.
- JavaScript is a subset of ECMAScript. JavaScript is basically ECMAScript at its core but builds upon it.Languages such as Action Script, JavaScript, JScript all use ECMAScript as its core. As a comparison, AS/JS/JScript are 3 different cars, but they all use the same engine each of their exteriors is different though, and there have been several modifications done to each to make it unique.
- ECMAScript is a specification for javascript and the latest version is 7 and it has features like Modules, promises, custom elements and shadow DOM which we can use to build the components instead of using a framework.
Journey of Web Stack Transformation from 2014 to 2019
In 2014 when aura framework was launched.At that time Web Standards had limited functionality and various framework came to fulfil the gaps like ReactJS,CommonJS,AngularJS etc.
- Aura framework ,Angular,React these all framework became languages.
- There was time when web developers rely heavily on frameworks.
But something very different happened to web browsers in the four years since the introduction of Aura.Google began to champion a new concept known as Web Components to the internet community. The idea was to scrap the decades-old limitations of what web browsers were capable of and agree to a new set of standards that would be more flexible and powerful to web developers.
Web Components was released to Google’s Chrome browser in 2014 and then it made its way through various committees within the tech community.
After some revisions and feedback from other companies such as Salesforce, the specifics were ultimately agreed upon and implemented.
- Now all major web browsers such as Mozilla Firefox, Apple Safari, and Microsoft Edge support the new standards, thus making the new technology widely available to the masses.
- A lot of the functionality that Salesforce had built into the Aura framework could now be taken out of their processes and offloaded onto the browser itself using Web Components.
LWC are able to utilize the new standards while still having the ability to access Salesforce data and work within the existing Lightning Experience UI.
This results in faster speeds and processing of Salesforce applications because the web browser has a more direct access to the processing capability of your computer. Salesforce can now focus their resources on Salesforce-specific functionality and not just creating a webpage for you.
4 Pillars of Web Component :
- Import : to import a class, function, or variable declared in a module. eg:import { LightningElement } from 'lwc' (here LightningElement is a custom wrapper of the standard HTML element.)
- Template : writing markup inside <template> tag.
- Custom Element: create a custom HTML tag.
- Shadow DOM : encapsulate structure and style from other elements.
Key Concept of LWC
Coexistence and Interoperability of LWC and Aura Component
1.Aura Components, leveraging its own component model, templates, and modular development programming model.
2.Lightning Web Components, built on top of the web standards breakthroughs of the last five years: web components, custom elements, Shadow DOM, etc
- An interoperability layer enables Lightning web components and Aura components to work together in an app.
- Lightning web components and Aura components can work together, but there are limitations that you must understand.
- Aura components can contain Lightning web components. However, the opposite doesn’t apply. Lightning web components can’t contain Aura components
- Lightning Components will continue working and being supported by Salesforce.
- Here the blue blocks( in above image) represents the custom layers running on top of browser (javascript engine) to make a lightning components work.
- In middle-left you can see a big chunk which represents Aura framework (custom).
- On middle-right, the orange block(in above image), represents the web component implementation within Browsers (native)
Advantage of using Lightning Web Component :
Lightning web components utilize more of native browser features and capabilities they are:
- Compliant to web standards
- Lightweight
- Memory efficient
- Fast
- Easier to learn
Happy learning :) and stay tuned will come up with lightning web component series.
Nice Blog sir
ReplyDeleteThank you Abhinav
Delete