SlideShare a Scribd company logo
Lightning Components 101
An Apex Developer’s Guide
Salesforce Engineer,
Adam Olshansky
New Delhi Salesforce DG
• First Revival Meetup in February 2016
• Twitter: https://twitter.com/newdelhisfdcdug
• Hashtag: #ImpactSalesforceSaturday
• New Delhi Salesforce DG Trailblazer Community Group: http://bit.ly/NewDelhiCommunity
• Website: https://newdelhisfdcdug.com
Mentorship Central
• We are dedicated to matching Mentees seeking specific Salesforce goals with Mentors
• Sign up as a Mentor or Mentee and connect with other Mentors/Mentees
• http://bit.ly/SFMentorshipCentral
630 14X
Adam Olshansky
Salesforce Engineer, Google
@adam17amo
adam@adamtoarchitect.com
bit.ly/lightningmigration
Speaker Logo
धन्यवाद
Developing a fear of heights
Further up the Mountain
Front end
JavaScript
Client side
Shadow DOM
Callback hell
Front End Language Usage
Stack Overflow Developer Survey, 2019
• 72,000+ responses
7th Year in a Row for JavaScript
Quarterly Data
• JavaScript is 20%+ of all requests
Apex is 39th
JavaScript #1 in GitHub Pull Requests since 2013
A Little Overwhelming
Backend is safe
Expectations
You’re an Apex Developer
Can’t learn JavaScript in 40 mins
Understand common patterns
Gain confidence to start building components
The First Step
Agenda
1. Apex Overview
2. Components
3. VF vs. Lightning Web Components
4. Lightning Web Components
5. Summary and Step 2
Apex Overview
Review of what we know
Apex Overview
Bread and Butter
Triggers
Classes/
Controllers
Variables
Methods
Parameters
Return values
Events
Async Apex
Wait for resources
Batchable
MVC Model
HTML style tags
Bind Variables
Bind Methods
Button based UI
Visualforce
Governor limits
Button click based
Poor Performance
Hacky solutions
Limitations
Apex and VF Gaps
A New Programming Model
MVC++
Customer Driven Paradigm Shift
August 2015
September
2007
January 2019
Everything on the Server
Where We Were - MVC
Client vs. Server
Moving to client side - MVCC
What is a “Lightning Component”?
Container for multiple files
Aura
Lightning
Web
Component
UI
Controller
CSS XML Metadata
Helper
Documentation
Design
SVG
What’s Old With Components?
Many similar things
UI Components
Event based code
Bind variables
Calling methods
Multiple files used
UI Components
Old Framework
New Names
<apex>
LWC Framework <html>, <lightning>, <c>
Event Based Code
Old Framework
New Names
before insert, after update
LWC Framework onchange, onclick
Bind Variables
Old Framework
Similar Syntax
{!variable}
LWC Framework {variable}
Bind Methods
Old Framework
Similar Syntax
{!methodName}
LWC Framework {methodName} or custom
Multiple Files
Old Framework
Similar to before
VF Page, Apex Controller, Apex Helper
LWC Framework HTML, JS Controller, Apex Controller
Let’s Compare
VF vs. LWC
Visualforce
HelloWorld.page
HelloWorldController.cls
Apex Controller
Lightning Web Component
HelloWorld.html
HelloWorldController.js
JS Controller
What did we just see?
Component markup
Code running based on events
Variable and method bindings
Controller part of the bundle
No Apex
Lightning Web Components
Embrace Standards
Standards Improved
Why Change?
Salesforce’s Response
Standardize
New with Web Components!
More to Learn
Industry Standards
Logic in one spot
Multiple Apex Controllers
Decorators
DEMO TIME
Focus on Concepts
ldsCreateRecord.html
Create Record Component
viewSource.html
Child Component
viewSource.js
Child Controller
ldsCreateRecord.html
Create Record Component
ldsCreateRecord.js
Create Record Controller
ldsCreateRecord.js
Create Record Controller
apexWireMethodToProperty.html
Apex Wire Component
apexWireMethodToProperty.html
Apex Wire Component
apexWireMethodToProperty.js
Apex Wire Controller
Apex
apexWireMethodToProperty.html
Apex Wire Component
apexWireMethodToProperty.html
Apex Wire Component
What did we just see?
Component markup
Variable and Method bindings
Decorators
• @track – private + rerender
• @api – public + rerender
• @wire – wired to method
Importing from anywhere
A lot of old, a little new
Not so scary
after all
Recap
How to take Step 2
Recap
Web development already popular
Salesforce evolves to meet demands
Front end has similarities to backend
LWC are the present and future
This is Step 1
Salesforce Resources
Component Libraries
• https://developer.salesforce.com/docs/component-library
Sample Gallery
• https://trailhead.salesforce.com/sample-gallery
Lightning Web Components
• https://lwc.dev
Trailmix
• https://sfdc.co/lwc
Resources from Salesforce Instructor
• https://bit.ly/aura2lwc
Style – Lightning Design System
SLDS
• https://lightningdesignsystem.com
Add styling without writing CSS
Utilities
Icons and Classes
Step 3
@adam17amo
adam@adamtoarchitect.com
bit.ly/lightningmigration
github.com/adam17amo/lwc101
Follow & Join New Delhi Salesforce DG
• Join to know about future events and to RSVP:
https://trailblazercommunitygroups.com/delhi-in-developers-group/
• Let’s start conversations on Success Community:
http://bit.ly/NewDelhiCommunity
• Follow us on Twitter: https://twitter.com/newdelhisfdcdug
• Hashtag: #ImpactSalesforceSaturday
• Follow us on Facebook: https://www.facebook.com/newdelhisfdcdug
• For all the content: https://newdelhisfdcdug.com
#ImpactSalesforceSaturday: Lightning Components 101: An Apex Developer’s Guide

More Related Content

PPTX
Connecticut Salesforce Developer Group - Jan 2017
PDF
The missing key: Azure AD for developers
PDF
DEVELOPING SHAREPOINT FRAMEWORK SOLUTIONS FOR THE ENTERPRISE
PPTX
Empower admins with the power of salesforce dx, git and cicd pipeline
PPTX
Lightning web components
PPTX
Intro to Salesforce Lightning Web Components (LWC)
PPTX
AUGNYC June 21 Presentations
PDF
Building Faster With Your Team's UI Kit
Connecticut Salesforce Developer Group - Jan 2017
The missing key: Azure AD for developers
DEVELOPING SHAREPOINT FRAMEWORK SOLUTIONS FOR THE ENTERPRISE
Empower admins with the power of salesforce dx, git and cicd pipeline
Lightning web components
Intro to Salesforce Lightning Web Components (LWC)
AUGNYC June 21 Presentations
Building Faster With Your Team's UI Kit

What's hot (20)

PPTX
Salesforce Apex Hours: Einstein Intent
PPTX
A Deep-Dive into Real-World SharePoint App Development
PPTX
ECS19 - Vesa Juvonen - Getting Started With SharePoint Framework - Roadmap
PDF
Creating a Business Oriented UI in APEX
PDF
Practical management of development & QA environments for SharePoint 2013
PDF
ECS19 - Michael Greth - Best Practice with Company Video on Microsoft Stream
PPTX
Salesforce Lightning Data Service
PDF
Lwc presentation
PPTX
Advanced PowerShell for Office 365
PDF
APEX 5 Demo and Best Practices
PDF
ECS19 - Thomas Vochten - ESSENTIAL DATABASE ADMINISTRATION SKILLS FOR SHAREPO...
PPTX
Lightning web components
PPTX
Salesforce Apex Hours: What means Winter 18 for Developers
PDF
[Collinge] Office 365 Enterprise Network Connectivity Using Published Office ...
PPTX
[Roine] Serverless: Don't Take It Literally
PDF
Mastering universal theme
PPTX
Lightning web components
PPT
APEX 5.1 features - AUSOUG Connect 2016
PDF
Connect First, Ask Confluence Questions Later
PPTX
LightSwitch
Salesforce Apex Hours: Einstein Intent
A Deep-Dive into Real-World SharePoint App Development
ECS19 - Vesa Juvonen - Getting Started With SharePoint Framework - Roadmap
Creating a Business Oriented UI in APEX
Practical management of development & QA environments for SharePoint 2013
ECS19 - Michael Greth - Best Practice with Company Video on Microsoft Stream
Salesforce Lightning Data Service
Lwc presentation
Advanced PowerShell for Office 365
APEX 5 Demo and Best Practices
ECS19 - Thomas Vochten - ESSENTIAL DATABASE ADMINISTRATION SKILLS FOR SHAREPO...
Lightning web components
Salesforce Apex Hours: What means Winter 18 for Developers
[Collinge] Office 365 Enterprise Network Connectivity Using Published Office ...
[Roine] Serverless: Don't Take It Literally
Mastering universal theme
Lightning web components
APEX 5.1 features - AUSOUG Connect 2016
Connect First, Ask Confluence Questions Later
LightSwitch
Ad

Similar to #ImpactSalesforceSaturday: Lightning Components 101: An Apex Developer’s Guide (20)

PPTX
Live Session1 lightning web component
PPTX
Lightning Web Component - LWC
PPTX
SFDC Lightning Demo
PPTX
Lightning web components
PDF
#DF2UFL 2012 - Developer’s Den
PDF
DF2UFL 2012: Developer's Den - What's New and What's on the Horizon
PPTX
Microsoft WebMatrix Platform Overview
PDF
WordCamp Asheville 2017 - So You Wanna Dev? Join the Team!
PDF
Seminar: Become a Reliable Web Programmer
PPTX
Hands-On Workshop: Introduction to Development on Force.com for Developers
PPTX
How we built nothingbutsharepoint.com on sharepoint 2010
PPTX
Implementing Vanilla Web Components
PDF
WordCamp Greenville 2018 - Beware the Dark Side, or an Intro to Development
PPTX
MongoDB.local Seattle 2019: MongoDB Stitch Tutorial
PPTX
Salesforce Apex Hours :- Introduction to lightning components
PDF
Advanced Flow Techniques with Apex and Visualforce
ODP
CRM Science - Dreamforce '14: From Admin to Developer: Learning to Code on F...
PPTX
MongoDB.local Atlanta: MongoDB Stitch Tutorial
PPTX
Mike Taulty MIX10 Silverlight Frameworks and Patterns
PPTX
SPS Monaco 2017 - The Lay of the Land of Client-Side Development circa 2017
Live Session1 lightning web component
Lightning Web Component - LWC
SFDC Lightning Demo
Lightning web components
#DF2UFL 2012 - Developer’s Den
DF2UFL 2012: Developer's Den - What's New and What's on the Horizon
Microsoft WebMatrix Platform Overview
WordCamp Asheville 2017 - So You Wanna Dev? Join the Team!
Seminar: Become a Reliable Web Programmer
Hands-On Workshop: Introduction to Development on Force.com for Developers
How we built nothingbutsharepoint.com on sharepoint 2010
Implementing Vanilla Web Components
WordCamp Greenville 2018 - Beware the Dark Side, or an Intro to Development
MongoDB.local Seattle 2019: MongoDB Stitch Tutorial
Salesforce Apex Hours :- Introduction to lightning components
Advanced Flow Techniques with Apex and Visualforce
CRM Science - Dreamforce '14: From Admin to Developer: Learning to Code on F...
MongoDB.local Atlanta: MongoDB Stitch Tutorial
Mike Taulty MIX10 Silverlight Frameworks and Patterns
SPS Monaco 2017 - The Lay of the Land of Client-Side Development circa 2017
Ad

More from New Delhi Salesforce Developer Group (20)

PPTX
ImpactSS | Introduction to Declarative Automation Tools
PPTX
How to Build Your Career in the Salesforce Ecosystem Part 1 | New Delhi Sales...
PPTX
KYC: Marketing Automation Part - 2
PPTX
KYC Marketing Automation Part - 1
PPTX
Introduction to Journey builder
PPTX
#ImpactSalesforceSaturday: Salesforce Solution design – Performance Considera...
PPTX
#ImpactSalesforceSaturday: Personal Branding Knows No Boundaries
PPTX
#ImpactSalesforceSaturday: Intro to digital marketing, Automation tools, SFMC...
PPTX
#ImpactSalesforceSaturday: All about Data Preparation
PPTX
#ImpactSalesforceSaturday: Introduction (Four Pillars of Einstein)
PPTX
#ImpactSalesforceSaturday: Einstein bot basic to advanced
PPTX
#ImpactSalesforceSaturday: Drum into understanding of prediction builder with...
PDF
#ImpactSalesforceSaturday: Prepare for Salesforce Certified Heroku Architectu...
PPTX
TrailheaDX 2020 Global Gathering (Virtual)
PPTX
#ImpactSalesforceSaturday: Email Marketing using Pardot
PPTX
#ImpactSalesforceSaturday: Pardot Forms And Form Handlers
PPTX
#ImpactSalesforceSaturday:360 degree view of salesforce integrations
PPTX
#ImpactSalesforceSaturday: Create a Chat Bot powered by Einstein Intent Predi...
PPTX
Hear.com (Johann Furmann)
PPTX
Sfdx presentation (Arpit) Hear.Com
ImpactSS | Introduction to Declarative Automation Tools
How to Build Your Career in the Salesforce Ecosystem Part 1 | New Delhi Sales...
KYC: Marketing Automation Part - 2
KYC Marketing Automation Part - 1
Introduction to Journey builder
#ImpactSalesforceSaturday: Salesforce Solution design – Performance Considera...
#ImpactSalesforceSaturday: Personal Branding Knows No Boundaries
#ImpactSalesforceSaturday: Intro to digital marketing, Automation tools, SFMC...
#ImpactSalesforceSaturday: All about Data Preparation
#ImpactSalesforceSaturday: Introduction (Four Pillars of Einstein)
#ImpactSalesforceSaturday: Einstein bot basic to advanced
#ImpactSalesforceSaturday: Drum into understanding of prediction builder with...
#ImpactSalesforceSaturday: Prepare for Salesforce Certified Heroku Architectu...
TrailheaDX 2020 Global Gathering (Virtual)
#ImpactSalesforceSaturday: Email Marketing using Pardot
#ImpactSalesforceSaturday: Pardot Forms And Form Handlers
#ImpactSalesforceSaturday:360 degree view of salesforce integrations
#ImpactSalesforceSaturday: Create a Chat Bot powered by Einstein Intent Predi...
Hear.com (Johann Furmann)
Sfdx presentation (Arpit) Hear.Com

Recently uploaded (20)

PPTX
Institutional Correction lecture only . . .
PPTX
school management -TNTEU- B.Ed., Semester II Unit 1.pptx
PDF
Anesthesia in Laparoscopic Surgery in India
PPTX
Cell Types and Its function , kingdom of life
PPTX
Introduction_to_Human_Anatomy_and_Physiology_for_B.Pharm.pptx
PDF
Mark Klimek Lecture Notes_240423 revision books _173037.pdf
PDF
BÀI TẬP BỔ TRỢ 4 KỸ NĂNG TIẾNG ANH 9 GLOBAL SUCCESS - CẢ NĂM - BÁM SÁT FORM Đ...
PDF
TR - Agricultural Crops Production NC III.pdf
PDF
Chapter 2 Heredity, Prenatal Development, and Birth.pdf
PPTX
PPT- ENG7_QUARTER1_LESSON1_WEEK1. IMAGERY -DESCRIPTIONS pptx.pptx
PDF
Origin of periodic table-Mendeleev’s Periodic-Modern Periodic table
PDF
Physiotherapy_for_Respiratory_and_Cardiac_Problems WEBBER.pdf
PPTX
Microbial diseases, their pathogenesis and prophylaxis
PDF
Module 4: Burden of Disease Tutorial Slides S2 2025
PDF
Complications of Minimal Access Surgery at WLH
PPTX
Pharmacology of Heart Failure /Pharmacotherapy of CHF
PDF
Supply Chain Operations Speaking Notes -ICLT Program
PDF
Microbial disease of the cardiovascular and lymphatic systems
PPTX
human mycosis Human fungal infections are called human mycosis..pptx
PDF
O5-L3 Freight Transport Ops (International) V1.pdf
Institutional Correction lecture only . . .
school management -TNTEU- B.Ed., Semester II Unit 1.pptx
Anesthesia in Laparoscopic Surgery in India
Cell Types and Its function , kingdom of life
Introduction_to_Human_Anatomy_and_Physiology_for_B.Pharm.pptx
Mark Klimek Lecture Notes_240423 revision books _173037.pdf
BÀI TẬP BỔ TRỢ 4 KỸ NĂNG TIẾNG ANH 9 GLOBAL SUCCESS - CẢ NĂM - BÁM SÁT FORM Đ...
TR - Agricultural Crops Production NC III.pdf
Chapter 2 Heredity, Prenatal Development, and Birth.pdf
PPT- ENG7_QUARTER1_LESSON1_WEEK1. IMAGERY -DESCRIPTIONS pptx.pptx
Origin of periodic table-Mendeleev’s Periodic-Modern Periodic table
Physiotherapy_for_Respiratory_and_Cardiac_Problems WEBBER.pdf
Microbial diseases, their pathogenesis and prophylaxis
Module 4: Burden of Disease Tutorial Slides S2 2025
Complications of Minimal Access Surgery at WLH
Pharmacology of Heart Failure /Pharmacotherapy of CHF
Supply Chain Operations Speaking Notes -ICLT Program
Microbial disease of the cardiovascular and lymphatic systems
human mycosis Human fungal infections are called human mycosis..pptx
O5-L3 Freight Transport Ops (International) V1.pdf

#ImpactSalesforceSaturday: Lightning Components 101: An Apex Developer’s Guide