Front End Handbook PDF
Front End Handbook PDF
of Contents
Introduction 1.1
What Is a Front-End Developer? 1.2
Part I: The Front-End Practice 1.3
Front-End Jobs Titles 1.3.1
Common Web Tech Employed 1.3.2
Front-End Dev Skills 1.3.3
Front-End Devs Develop For... 1.3.4
Front-End on a Team 1.3.5
Generalist Myth 1.3.6
Front-End interview questions 1.3.7
Front-End Job Boards 1.3.8
Front-End Salaries 1.3.9
How FDs Are Made 1.3.10
Part II: Learning Front-End Dev 1.4
Self Directed Learning 1.4.1
Learn Internet/Web 1.4.1.1
Learn Web Browsers 1.4.1.2
Learn DNS 1.4.1.3
Learn HTTP/Networks 1.4.1.4
Learn Web Hosting 1.4.1.5
Learn General Front-End Dev 1.4.1.6
Learn UI/Interaction Design 1.4.1.7
Learn HTML & CSS 1.4.1.8
Learn SEO 1.4.1.9
Learn JavaScript 1.4.1.10
Learn Web Animation 1.4.1.11
Learn DOM, BOM & jQuery 1.4.1.12
Learn Web Fonts 1.4.1.13
Learn Accessibility 1.4.1.14
Learn Web/Browser APIs 1.4.1.15
2
Learn JSON 1.4.1.16
Learn JS Templates 1.4.1.17
Learn Static Site Generators 1.4.1.18
Learn Front-End App Architecture 1.4.1.19
Learn Interface/API Design 1.4.1.20
Learn Web Dev Tools 1.4.1.21
Learn Command Line 1.4.1.22
Learn Node.js 1.4.1.23
Learn Module Loader 1.4.1.24
Learn Package Managers 1.4.1.25
Learn Version Control 1.4.1.26
Learn Build & Task Automation 1.4.1.27
Learn Site Performance Optimization 1.4.1.28
Learn JS Testing 1.4.1.29
Learn Headless Browsers 1.4.1.30
Learn Offline Dev 1.4.1.31
Learn Security 1.4.1.32
Learn Multi-Thing Dev (e.g., RWD) 1.4.1.33
Directed Learning 1.4.2
Front-End Schools, Courses, & Bootcamps 1.4.2.1
Front-End Devs to Learn From 1.4.3
Newsletters, News, & Podcasts 1.4.4
Part III: Front-End Dev Tools 1.5
General Front-End Dev Tools 1.5.1
Doc/API Browsing Tools 1.5.2
SEO Tools 1.5.3
Prototyping & Wireframing Tools 1.5.4
Diagramming Tools 1.5.5
HTTP/Network Tools 1.5.6
Code Editing Tools 1.5.7
Browser Tools 1.5.8
HTML Tools 1.5.9
CSS Tools 1.5.10
DOM Tools 1.5.11
3
JavaScript Tools 1.5.12
Static Site Generators Tools 1.5.13
App (Desktop, Mobile, Tablet, etc.) Tools 1.5.14
Scaffolding Tools 1.5.15
Templating Tools 1.5.16
UI Widgets & Components Tools 1.5.17
Data Visualization (e.g., Charts) Tools 1.5.18
Graphics (e.g., SVG, canvas, webgl) Tools 1.5.19
Animation Tools 1.5.20
JSON Tools 1.5.21
Testing Framework Tools 1.5.22
Data Storage Tools 1.5.23
Module/Package Loading Tools 1.5.24
Module/Package Repo. Tools 1.5.25
Web/Cloud/Static Hosting Tools 1.5.26
Project Management & Code Hosting 1.5.27
Collaboration & Communication Tools 1.5.28
CMS Hosted/API Tools 1.5.29
BAAS (for Front-End Devs) Tools 1.5.30
Offline Tools 1.5.31
Security Tools 1.5.32
Tasking (aka Build) Tools 1.5.33
Deployment Tools 1.5.34
Site/App Monitoring Tools 1.5.35
JS Error Monitoring Tools 1.5.36
Performance Tools 1.5.37
4
Introduction
This is a guide that anyone could use to learn about the practice of front-end development. It
broadly outlines and discusses the practice of front-end engineering: how to learn it and
what tools are used when practicing it.
It is specifically written with the intention of being a professional resource for potential and
currently practicing front-end developers to equip themselves with learning materials and
development tools. Secondarily, it can be used by managers, CTOs, instructors, and head
hunters to gain insights into the practice of front-end development.
The content of the handbook favors web technologies (HTML, CSS, DOM, and JavaScript)
and those solutions that are directly built on top of these open technologies. The materials
referenced and discussed in the book are either best in class or the current offering to a
problem.
The book should not be considered a comprehensive outline of all resources available to a
front-end developer. The value of the book is tied up in a terse, focused, and timely curation
of just enough categorical information so as not to overwhelm anyone on any one particular
subject matter.
5
Introduction
https://www.gitbook.com/book/frontendmasters/front-end-handbook/details
https://github.com/FrontendMasters/front-end-handbook
6
What Is a Front-End Developer?
Typically, a person enters into the field of front-end development by learning to develop
HTML, CSS, and JS code, which runs in a web browser, headless browser, WebView, or as
compilation input for a native runtime environment. The four run times scenarios are
explained below.
A web browser is software used to retrieve, present, and traverse information on the WWW.
Typically, browsers run on a desktop, laptop, tablet, or phone, but as of late a browser can
be found on just about anything (i.e, on a fridge, in cars, etc.).
Chrome
Internet Explorer
Firefox
Safari
Headless browsers are a web browser without a graphical user interface that can be
controlled from a command line interface for the purpose of web page automation (e.g.,
functional testing, scraping, unit testing, etc.). Think of headless browsers as a browser that
you can run from the command line that can retrieve and traverse web pages.
PhantomJS
7
What Is a Front-End Developer?
slimerjs
trifleJS
Webviews are used by a native OS, in a native application, to run web pages. Think of a
webview like an iframe or a single tab from a web browser that is embedded in a native
application running on a device (e.g., iOS, android, windows).
Eventually, what is learned from web browser development can be used by front-end
developers to craft code for environments that are not fueled by a browser engine. As of
late, development environments are being dreamed up that use web technologies (e.g., CSS
and JavaScript), without web engines, to create truly native applications.
NativeScript
React Native
8
Part I: The Front-End Practice
9
Front-End Jobs Titles
The generic job title that describes a developer who is skilled to some degree at HTML,
CSS, DOM, and JavaScript and implementing these technologies on the web platform.
CSS/HTML Developer
The front-end job title that describes a developer who is skilled at HTML and CSS, excluding
JavaScript and Application know how.
When the word "JavaScript Application" is included in the job title, this will denote that the
developer should be an advanced JavaScript developer possessing advanced
programming, software development, and application development skills (i.e will have solid
experience building front-end applications).
When the word "Designer" is included in the job title, this will denote that the designer will
posses front-end skills (i.e., HTML & CSS) but also professional design (Visual Design and
Interaction Design) skills.
10
Front-End Jobs Titles
When the word "Interface" or "UI" is included in the job title, this will denote that the
developer should posses interaction design skills in addition to front-end skills.
When the word "Mobile" or "Tablet" is included in the job title, this will denote that the
developer has experience developing front-ends that run on mobile or tablet devices (either
natively or on the web platform, i.e., in a browser).
When the word "SEO" is included in the job title, this will denote that the developer has
extensive experience crafting front-end technologies towards an SEO strategy.
When the word "Acessibility" is included in the job title, this will denote that the developer
has extensive experience crafting front-end technologies that support accessibility
requirements and standards.
When the word "DevOps" is included in the job title, this will denote that the developer has
extensive experience with software development practices pertaining to collaboration,
integration, deployment, automation, and measurement.
Front-End Testing/QA
When the word "Testing" or "QA" is included in the job title, this will denote that the
developer has extensive experience testing and managing software that involves unit
testing, functional testing, user testing, and A/B testing.
Note that if you come across the "Full Stack" or the generic "Web Developer" terms in job
titles these words may be used by an employer to describe a role that is responsible for all
aspects of web/app development, i.e., both front-end (potentially including design) and back-
11
Front-End Jobs Titles
end.
12
Common Web Tech Employed
These technologies are defined below with the relevant documentation and specifications.
For a comprehensive list of all web related specifications have a look at platform.html5.org.
13
Common Web Tech Employed
Wikipedia
Cascading Style Sheets (CSS) is a style sheet language used for describing the look
and formatting of a document written in a markup language. Although most often used
to change the style of web pages and user interfaces written in HTML and XHTML, the
language can be applied to any kind of XML document, including plain XML, SVG and
XUL. Along with HTML and JavaScript, CSS is a cornerstone technology used by most
websites to create visually engaging webpages, user interfaces for web applications,
and user interfaces for many mobile applications.
Wikipedia
14
Common Web Tech Employed
Wikipedia
Wikipedia
When writing code for the Web using JavaScript, there are a great many APIs available.
Below is a list of all the interfaces (that is, types of objects) that you may be able to use
while developing your Web app or site.
Mozilla
15
Common Web Tech Employed
Wikipedia
Wikipedia
Wikipedia
Introducing JSON
JSON API
16
Common Web Tech Employed
Web Content Accessibility Guidelines (aka WCAG) & Accessible Rich Internet
Applications (aka ARIA)
Wikipedia
17
Front-End Dev Skills
Basic to advanced HTML, CSS, DOM, JavaScript, HTTP/URL, and browser skills are
assumed for any type of front-end developer.
Beyond HTML, CSS, DOM, JavaScript, HTTP/URL, and browser development, a front-end
developer could be skilled in one or more of the following:
18
Front-End Dev Skills
19
Front-End Devs Develop For...
Android
Chromium
iOS
OS X
Ubuntu (or some flavor of Linux)
Windows Phone
Windows
These operating systems typically run on one or more of the following devices:
Desktop computer
Laptop / Netbook computer
Mobile phone
Tablet
TV
Watch
Things (i.e., anything you can imagine, car, refrigerator, lights, thermostat, etc.)
20
Front-End Devs Develop For...
21
Front-End on a Team
Front-End on a Team
A front-end developer is typically only one player on a team that designs and develops web
sites, web applications, or native applications running on web technologies. (Note: A
developer who builds everything was once called a "web master" but as of late these rare
and mythical developers are called "full-stack developers").
A bare bones team for building professional sites or software on the web will minimally
contain the following roles.
Visual Designer (i.e., fonts, colors, spacing, emotion, visuals concepts & themes)
UI/Interaction Designer/Information Architect (i.e., wireframes, specifying all user
interactions and UI functionality, structuring information)
Front-End Developer (i.e., writes code that runs in client/on device)
Back-End Developer (i.e., writes code that runs on server)
The roles are ordered according to overlapping skills. A front-end developer will typically
have a good handle on UI/Interaction design as well as back-end development. It is not
uncommon for team members to fill more than one role by taking on the responsibilities of
an over-lapping role.
It is assumed that the team mentioned above is being directed by a project lead or some
kind of product owner (i.e., stakeholder, project manager, project lead, etc.)
A larger web team might include the following roles not shown above:
Visual Designers
Interface Design/Interaction Designer/Information Design
SEO Strategist
Front-End Developer
DevOps Engineers
Back-End Developer
API Developer
Database Administrator
QA Engineer / Testers
22
Generalist Myth
Generalist Myth
The roles required to design and develop a web solution require a deep skill set and vast
experience in the area of visual design, UI/interaction design, front-end development, and
back-end development. Any person (aka generalist or full-stack developer/designer) who
can fill one or more of these 4 roles at a professional level is a rare exception to the rule.
Pragmatically, you should seek to be, or seek to hire, an expert in one of these roles. Those
who claim to operate at an expert level at one or more of these roles are exceptionally rare
and more than likely mythical, given modern stacks.
23
Generalist Myth
24
Front-End interview questions
Front-End Interviews
Questions you may get asked:
25
Front-End Job Boards
angularjobs.com
authenticjobs.com
careers.stackoverflow.com
css-tricks.com/jobs
frontenddeveloperjob.com
glassdoor.com
jobs.emberjs.com
jobs.github.com
weworkremotely.com
26
Front-End Salaries
Front-End Salaries
The national average in the U.S for a front-end developer is $75k.
An experienced front-end developer potentially can live wherever they want (i.e., work
remotely) and make over $150k a year (visit angel.co, sign-up, review front-end jobs over
$150k).
27
How FDs Are Made
How exactly does one become a front-end developer? Well, it's complicated. Still today you
can't go to college and expect to graduate with a degree in front-end engineering. And, I
rarely hear of or meet front-end developers who suffered through what is likely a deprecated
computer science degree or graphic design degree to end up writing HTML, CSS, and
JavaScript professionally. In fact, most of the people working on the front-end, even today,
generally seem to be self taught and not traditionally trained as a programmer. Why is this
the case?
28
How FDs Are Made
A front-end engineer crafts the skeleton that the user interface rests upon. They must, at
times, care as much about the interaction design as they do about the underlying code that
creates the UI interactions. Therefore, many in practice today do not come to front-end
engineering with programming skills, but, instead, from the other direction. That is, front-end
development seems to be filled with more designer types turned developer than programmer
types turned front-end developer. Of course, as JavaScript has grown up, so has the desire
by more traditionally trained programmers to bring their knowledge to the front-end practice.
If you are not aware, front-end developers have not always been considered by "real"
programmers as, well, programmers. But times are a changing.
With all of that said, I believe that the path to a career as a front-end developer is very much
an unknown process. What I can say is that to become a front-end engineer one must know
and use HTML, CSS, DOM, and JavaScript at a deep level without ignoring interaction
design or traditional programming know how. In fact, from my experience, the best front-end
developers often have a mastery understanding of interaction design and programming, but
from the context of the web platform (i.e., browsers, HTML, CSS, DOM, and JavaScript).
And for whatever reason, this knowledge is often discovered/approached not given. That is
to say, front-end engineering still seems very much to be a practice made up of self taught
people, as opposed to a field that corresponds directly to an educational focus from an
organized and accredited higher learning situation.
If you were to set out today to become a front-end developer I would loosely strive to follow
the process outlined below. The process assumes you are your own best teacher.
1. Learn, roughly, how the web works. Make sure you know the "what" and "where" of
Domains, DNS, URLs, HTTP, networks, browsers, servers/hosting, databases, JSON,
data APIs, HTML, CSS, DOM, and JavaScript. The goal is to make sure you loosely
know how it all works together and exactly what each part is doing. Focus on the high
level outlines for front-end architectures. Start with simple web pages and briefly study
native web applications (aka SPAs).
2. Learn HTML, CSS, Accessibility, and SEO.
3. Learn the fundamentals of UI design patterns, interaction design, user experience
design, and usability.
4. Learn the fundamentals of programming
5. Learn JavaScript
6. Learn JSON and data APIs
7. Learn CLI/command line
8. Learn the practice of software engineering (i.e., Application design/architecture,
templates, Git, testing, monitoring, automating, code quality, development
methodologies).
9. Get opinionated and customize your tool box with whatever makes sense to your brain.
10. Learn Node.js
29
How FDs Are Made
Where you actually stop in the process is what will separate a front-end HTML/CSS
developer from an expert level front-end application/JavaScript developer.
A short word of advice on learning. Learn the actual underlying technologies, before learning
abstractions. Don't learn jQuery, learn the DOM. Don't learn SASS, learn CSS. Don't learn
HAML, learn HTML. Don't learn CoffeeScript, learn JavaScript. Don't learn Handlebars, learn
JavaScript ES6 templates. Don't just use Bootstrap, learn UI patterns. When getting your
start, you should fear most things that conceal complexity. Abstracts in the wrong hands can
give the appearance of advanced skills, while all the time hiding the fact that a developer
has an inferior understanding of the basics or underlying concepts. In short, a skilled front-
end developer does not take a broken car to a mechanic, they are the mechanic.
The rest of this book points a reader to the resources and tools to follow my previously
suggested process. It is assumed that you are not only learning, but also doing as you learn
and investigate tools. Some suggest only doing. While others suggest only learning about
doing. I suggest you find a mix of both that matches how your brain works and do that. But,
for sure, it is a mix! So, don't just read about it, do it. Learn, do. Learn, do. Repeat
indefinitely because things change fast. This is why learning the fundamentals, and not
abstractions, are so important.
I should mention that lately a lot of non-accredited front-end code schools/bootcamps have
emerged. These avenues of becoming a front-end developer are teacher directed in
classroom (virtual and physical) courses, which follow a more traditional style of learning
from an official instructor (i.e., syllabus, test, quizzes, projects, team projects, grades, etc.). I
have more to say about these institutions in the direct learning section of this handbook. In
brief, this is the web, everything you need to learn is on the web for the taking (costing little
to nothing). However, if you need someone to tell you how to take what is actually free, and
hold you accountable for learning it, you might consider an organized course. Otherwise, I
am not aware of any other profession that is practically free for the taking with an internet
connection and a burning desire for knowledge.
If you want to get started immediately I'd suggest the following general overviews of the
practice of front-end development:
30
How FDs Are Made
31
Part II: Learning Front-End Dev
Note that just because a learning resource is listed, or a category of learning is documented,
I am not suggesting that a front-end developer learn everything. That would be absurd.
Choose your own slice of expertise within the profession. I'm providing the possibilities of
what could be mastered in the field.
32
Self Directed Learning
The resources include free material and paid material. Paid material will be indicated with
[$].
The author believes that anyone with the right determination and dedication can teach
themselves how to be a front-end developer. All that is required is a computer connected to
the web and some cash for books and video training.
Below are a few video learning outlets (tech focused) I generally recommend pulling content
from:
codecademy.com
codeschool.com
egghead.io
eventedmind.com
Frontend Masters
Khan Academy
laracasts.com
lynda.com [careful, quality varies]
mijingo.com
pluralsight.com [careful, quality varies]
Tagtree
Treehouse
tutsplus.com
Udacity [careful, quality varies]
33
Learn Internet/Web
Learn Internet/Web
The Internet is a global system of interconnected computer networks that use the
Internet protocol suite (TCP/IP) to link several billion devices worldwide. It is a network
of networks that consists of millions of private, public, academic, business, and
government networks of local to global scope, linked by a broad array of electronic,
wireless, and optical networking technologies. The Internet carries an extensive range
of information resources and services, such as the inter-linked hypertext documents
and applications of the World Wide Web (WWW), electronic mail, telephony, and peer-
to-peer networks for file sharing.
Wikipedia
34
Learn Web Browsers
Wikipedia
35
Learn Web Browsers
evolutionoftheweb.com [read]
Timeline of web browsers [read]
Browser Security
36
Learn Web Browsers
Security for Web Developers: Using JavaScript, HTML, and CSS [read][$]
The Tangled Web: A Guide to Securing Modern Web Applications read
Comparing Browsers
In the past, a front-end developer spent a lot of time making code work in several different
browsers. This was once a bigger issue than it is today, unless you have to write code for
older browsers (i.e., <IE8). This still remains an issue today, just not one that demands so
much of the front-end developers time and brain cycles. The fact of the matter is modern
abstractions (e.g., jQuery, pre-processors, transpilers) have done away with a lot of browser
inconsistency issues.
Evergreen Browsers
The latest versions of browsers are considered evergreen browsers. That is, in theory they
are suppose to automatically update themselves silently without prompting the user. This
move towards self updating browsers has been in reaction to the slow process of eliminating
older browsers. Older browsers are complicated to develop for given their deviations from
the commonalities between modern browsers (i.e., new specifications and this rate of
change).
Picking a Browser
As of today, most front-end developers use Chrome and the tools available to a developer,
"Chrome Dev Tools". However, all of the browsers offer a flavor of developer tools. Picking
one to use for development is a subjective matter. The more important issue is knowing
which browsers you have to support and testing in each as you develop. Select whichever
browser makes sense to your brain and gets the job done. I suggest using Chrome simply
because the developer tools are consistently improving and at this time contain the most
robust features.
Browser Hacks
browserhacks.com [read]
37
Learn DNS
Wikipedia
38
Learn DNS
39
Learn HTTP/Networks
Wikipedia
Wikipedia
Wikipedia
HTTP
High Performance Browser Networking: What Every Web Developer Should Know
About Networking and Web Performance [read]
HTTP/2 Frequently Asked Questions [read]
HTTP Fundamentals [watch][$]
HTTP: The Protocol Every Web Developer Must Know - Part 1 [read]
HTTP: The Protocol Every Web Developer Must Know - Part 2 [read]
HTTP Succinctly [read]
CORS
WebSockets
40
Learn HTTP/Networks
41
Learn Web Hosting
Wikipedia
General Learning:
42
Learn General Front-End Dev
43
Learn UI/Interaction Design
Wikipedia
Wikipedia
User Experience Design - User Experience Design (UXD or UED or XD) is the
process of enhancing user satisfaction by improving the usability, accessibility, and
pleasure provided in the interaction between the user and the product. User experience
design encompasses traditional humancomputer interaction (HCI) design, and
extends it by addressing all aspects of a product or service as perceived by users.
Wikipedia
Wikipedia
Minimally I'd suggest reading the following canonical texts on the matter so one can build
proper user interfaces.
44
Learn UI/Interaction Design
45
Learn HTML & CSS
Wikipedia
CSS - Cascading Style Sheets (CSS) is a style sheet language used for describing the
look and formatting of a document written in a markup language. Although most often
used to change the style of web pages and user interfaces written in HTML and
XHTML, the language can be applied to any kind of XML document, including plain
XML, SVG and XUL. Along with HTML and JavaScript, CSS is a cornerstone
technology used by most websites to create visually engaging webpages, user
interfaces for web applications, and user interfaces for many mobile applications.
Wikipedia
Liken to constructing a house, one might consider HTML the framing and CSS to be the
painting & decorating.
General Learning:
Mastering:
46
Learn HTML & CSS
References/Docs:
Glossary:
CSS Glossary - Programming Reference for CSS Covering Comments, Properties, and
Selectors
HTML Glossary Programming Reference for HTML elements
Standards/Specifications:
Architecting CSS:
Authoring Conventions:
cssguidelin.es [read]
47
Learn HTML & CSS
HTML/CSS Newsletters:
CSS Weekly
HTML 5 Weekly
48
Learn SEO
Wikipedia
General Learning:
49
Learn JavaScript
Learn JavaScript
JavaScript is a high level, dynamic, untyped, and interpreted programming language. It
has been standardized in the ECMAScript language specification. Alongside HTML and
CSS, it is one of the three essential technologies of World Wide Web content
production; the majority of websites employ it and it is supported by all modern web
browsers without plug-ins. JavaScript is prototype-based with first-class functions,
making it a multi-paradigm language, supporting object-oriented, imperative, and
functional programming styles. It has an API for working with text, arrays, dates and
regular expressions, but does not include any I/O, such as networking, storage or
graphics facilities, relying for these upon the host environment in which it is embedded.
Wikipedia
General Learning:
Mastering:
50
Learn JavaScript
References/Docs:
Glossary/Encyclopedia/Jargon:
Standards/Specifications:
Style:
Echo JS
FiveJS
JavaScript Jabber
JavaScript Kicks
JavaScript Live
JavaScript Weekly
JavaScript.com
51
Learn JavaScript
52
Learn Web Animation
Standards/Specifications:
Web Animations
53
Learn DOM, BOM & jQuery
Wikipedia
Wikipedia
Wikipedia
The ideal path, but certainly the most difficult, would be to first learn JavaScript, then the
DOM, then jQuery. However, do what makes sense to your brain. Most front-end developers
learn about JavaScript and then DOM by way of first learning jQuery. Whatever path you
take, just make sure JavaScript, then DOM, or jQuery don't become a black box.
General Learning:
Mastering:
54
Learn DOM, BOM & jQuery
References/Docs:
jQuery Docs
MDN Browser Object Model
MDN Document Object Model
MDN Event reference
MSDN Document Object Model (DOM)
Standards/Specifications:
55
Learn Web Fonts
The CSS2 specification was released in 1998 and attempted to improve the font
selection process by adding font matching, synthesis and download. These techniques
did not gain much use, and were removed in the CSS2.1 specification. However,
Internet Explorer added support for the font downloading feature in version 4.0,
released in 1997. Font downloading was later included in the CSS3 fonts module, and
has since been implemented in Safari 3.1, Opera 10 and Mozilla Firefox 3.5. This has
subsequently increased interest in Web typography, as well as the usage of font
downloading.
Wikipedia
General Learning:
56
Learn Accessibility
Learn Accessibility
Accessibility refers to the design of products, devices, services, or environments for
people with disabilities. The concept of accessible design ensures both direct access
(i.e., unassisted) and "indirect access" meaning compatibility with a person's assistive
technology (for example, computer screen readers).
Accessibility can be viewed as the "ability to access" and benefit from some system or
entity. The concept focuses on enabling access for people with disabilities, or special
needs, or enabling access through the use of assistive technology; however, research
and development in accessibility brings benefits to everyone.
Accessibility is not to be confused with usability, which is the extent to which a product
(such as a device, service, or environment) can be used by specified users to achieve
specified goals with effectiveness, efficiency and satisfaction in a specified context of
use.
Wikipedia
General Learning:
Standards/Specifications:
57
Learn Accessibility
58
Learn Web/Browser APIs
devices.
You should be aware of and learn, where appropriate, web/browser APIs. A good tool to use
to familiarize oneself with all of these APIs would be to investigate the HTML5test.com
results for the 5 most current browsers.
Learn:
59
Learn Web/Browser APIs
Learn Audio:
Learn Canvas:
Keep in mind that not every API is specified by the W3C or WHATWG.
60
Learn JSON
Although originally derived from the JavaScript scripting language, JSON is a language-
independent data format. Code for parsing and generating JSON data is readily
available in many programming languages.
Wikipedia
General Learning:
References/Docs:
json.org [read]
Standards/Specifications:
Architecting:
JSON API
61
Learn JS Templates
Learn JS Templates
A JavaScript template is typically used, but not always with a MV* solution to separate parts
of the view (i.e., the UI) from the logic and model (i.e., the data or JSON).
Note that JavaScript 2015 (aka ES6) has a native templating mechanism called "Templates
strings".
62
Learn Static Site Generators
General Learning:
63
Learn Front-End App Architecture
64
Learn Interface/API Design
JavaScript APIs
65
Learn Web Dev Tools
Web development tools come as browser add-ons or built in features in web browsers.
The most popular web browsers today like, Google Chrome, Firefox, Opera, Internet
Explorer, and Safari have built in tools to help web developers, and many additional
add-ons can be found in their respective plugin download centers.
Web development tools allow developers to work with a variety of web technologies,
including HTML, CSS, the DOM, JavaScript, and other components that are handled by
the web browser. Due to the increasing demand from web browsers to do more popular
web browsers have included more features geared for developers.
Wikipedia
While most browsers come equipped with web developer tools, the Chrome developer tools
are currently the most talked about and widely used tools available.
I'd suggest learning and using the Chrome web developer tools, simply because the best
resources for learning web developer tools revolves around Chrome DevTools.
News/Newsletters/Podcasts/Tips:
Dev Tips
66
Learn Web Dev Tools
67
Learn Command Line
Wikipedia
General Learning:
Mastering:
68
Learn Node.js
Learn Node.js
Node.js is an open-source, cross-platform runtime environment for developing server-
side web applications. Node.js applications are written in JavaScript and can be run
within the Node.js runtime on OS X, Microsoft Windows, Linux, FreeBSD, NonStop,[3]
IBM AIX, IBM System z and IBM i. Its work is hosted and supported by the Node.js
Foundation,[4] a collaborative project at Linux Foundation.[5]
Wikipedia
General Learning:
69
Learn Module Loader
browserify-handbook [read]
Choose ES6 modules Today! [read]
Creating JavaScript Modules with Browserify [watch][$]
Start your own JavaScript library using webpack and ES6
Webpack Fundamentals [watch][$]
References/Docs:
browserify
system.js
webpack
70
Learn Package Managers
Wikipedia
General Learning:
References/Docs:
bower
jspm.io
npm
71
Learn Version Control
Wikipedia
The current modern solution for version control is Git. Learn it!
General Learning:
codeschool.com [interact]
Getting Git Right [read]
Git Fundamentals [watch][$]
Pro Git [read]
Ry's Git Tutorial [read]
Mastering:
References/Docs:
https://git-scm.com/doc
72
Learn Build & Task Automation
Wikipedia
General Learning:
References/Docs:
Gulp
Gulp is great. However, you might only need npm run . Before turning to additional
complexity in your application stack ask yourself if npm run can do the job. If you need
more, use both.
Read:
73
Learn Site Performance Optimization
Wikipedia
General Learning:
74
Learn JS Testing
Learn JS Testing
Unit Testing - In computer programming, unit testing is a software testing method by
which individual units of source code, sets of one or more computer program modules
together with associated control data, usage procedures, and operating procedures, are
tested to determine whether they are fit for use. Intuitively, one can view a unit as the
smallest testable part of an application.
Wikipedia
Functional Testing - Functional testing is a quality assurance (QA) process and a type
of black box testing that bases its test cases on the specifications of the software
component under test. Functions are tested by feeding them input and examining the
output, and internal program structure is rarely considered (not like in white-box
testing). Functional testing usually describes what the system does.
Wikipedia
Wikipedia
General Learning:
75
Learn Headless Browsers
Wikipedia
76
Learn Offline Dev
General Learning:
77
Learn Security
Learn Security
Browser Security Handbook [read]
Frontend Security [watch]
HTML5 Security Cheatsheet [read]
Security for Web Developers: Using JavaScript, HTML, and CSS [read][$]
The Tangled Web: A Guide to Securing Modern Web Applications [read][$]
Web Security Basics [read]
78
Learn Multi-Thing Dev (e.g., RWD)
A site or application can run on a wide range of computers, laptops, tablets and phones, as
well as a handful of other things (watches, thermostats, fridges, etc.). How you determine
what things you'll support and how you will develop to support those things is called a multi-
79
Learn Multi-Thing Dev (e.g., RWD)
thing development strategy. Below, I list the most common multi-thing development
strategies.
General Learning:
80
Directed Learning
Directed Learning
This section focuses on directed learning via schools, courses, programs and bootcamps.
81
Front-End Schools, Courses, & Bootcamps
Directed Learning
The table below contains instructor led, paid, front-end courses, programs, schools, and
bootcamps.
If you can't afford a directed education, a self directed education using screencasts, books,
and articles is a viable alternative to learn front-end development for the self-driven
individual.
82
Front-End Schools, Courses, & Bootcamps
2,490
Austin Coding
The Front End Track per Austin, TX
Academy
session
Front-end Web Baltimore,
Betamore 8,500
Development MD
Become a Frontend
BLOC 4,999 yes
Developer
San
Night Front-End
Codeup 8,500 Antonio,
Bootcamp
Texas
Front-end Web multiple
Codify Academy 4,000
Development locations
Learn Front-end Web Montreal,
DecodeMTL 2,500
Development QC
83
Front-End Devs to Learn From
84
Newsletters, News, & Podcasts
HTML/CSS Newsletters:
CSS Weekly
HTML 5 Weekly
Echo JS
FiveJS
JavaScript Jabber
JavaScript Kicks
JavaScript Live
JavaScript Weekly
JavaScript.com
85
Newsletters, News, & Podcasts
86
Part III: Front-End Dev Tools
Make sure you understanding the category that a set of tools falls within, before studying the
tools themselves.
Note that just because a tool is listed, or a category of tools is documented, this does not
equate to an assertion on my part that a front-end developer should learn it and use it.
Choose your own toolbox. I'm just providing the common toolbox options.
87
General Front-End Dev Tools
Browsersync
CodeKit
ish. 2.0.
placehold.it
Prepros
screensiz.es
Wraith
CodePen
es6fiddle.net
JS Bin
JSFiddle
Liveweave
Plunker
built with
javascripting.com
microjs.com
stackshare.io
stylesheets.co
The Toolbox
Unheap
88
Doc/API Browsing Tools
89
SEO Tools
SEO Tools
Keyword Tool
Google Webmasters Search Console
Varvy SEO tool
90
Prototyping & Wireframing Tools
Collaboration / Presenting:
InVision [free to $]
Conceptboard [free to $]
myBalsamiq [$]
91
Diagramming Tools
Diagramming Tools
draw.io [free to $]
Cacoo [free to $]
gliffy [free to $]
92
HTTP/Network Tools
HTTP/Network Tools
Charles [$]
Chrome DevTools Network Panel
Fiddler
Postman
93
Code Editing Tools
Wikipedia
Front-end code can minimally be edited with a simple text editing application like Notepad or
TextEdit. But, most front-end practitioners use a code editor specifically design for editing a
programming language.
Code editors come in all sorts of types and size, so to speak. Selecting one is a rather
subjective engagement. Choose one, learn it inside and out, then get on to learning HTML,
CSS, DOM, and JavaScript.
However, I do strongly believe, minimally, a code editor should have the following qualities
(by default or by way of plugins):
I personally use and recommend Sublime Text with the following plug-ins.
AutoFileName
BracketHighlighter
Color Highlighter
CSS3
HTMLAttributes
HTML-CSS-JS Prettify
Package Control
SideBarEnhancements
StringEncode
94
Code Editing Tools
SublimeLinter
SublimeLinter-json
SublimeLinter-jshint
SublimeLinter-html-tidy
Terminal
Code Editors:
Atom
Brackets
Sublime Text [$]
WebStorm [$]
Visual Studio Code
Cloud9 [free to $]
Codeanywhere [free to $]
Koding [free to $]
Used to share limited amounts of immediately runnable code. Not a true code editor but a
tool that can be used to small amounts of immediately runnable code in a web browser.
CodePen [free to $]
es6fiddle.net
jsbin.com [free to $]
jsfiddle.net
liveweave.com
Plunker
95
Browser Tools
Browser Tools
JS Browser Coding Utilities:
History.js
html2canvas
Platform.js
URI.js
Big JS-Compatibility-Table
Browser support for broken/missing images
Browserscope
caniuse.com
Firefox Platform Status - Implementation & standardization roadmap for web platform
features
HTML5 Please
HTML5 Test
iwanttouse.com/
jscc.info
Platform Status
webbrowsercompatibility.com
whatwebcando.today
Browsersync
96
Browser Tools
ES Feature Tests
Feature.js
Modernizr
console-polyfill
HTML5 Cross Browser Polyfills
socket.io
SockJS
webcomponents.js
webshim
Browserling [$]
BrowserStack [$]
CrossBrowserTesting.com [$]
Sauce Labs [$]
Selenium
Headless Browsers:
PhantomJS
slimerjs
TrifleJS
CasperJS
gremlins.js
Nightmare
NightwatchJS
Browser Hacks:
browserhacks.com
97
HTML Tools
HTML Tools
HTML Templates/Boilerplates/Starter Kits:
dCodes
Email-Boilerplate
HTML5 Boilerplate
HTML5 Bones
Mobile boilerplate
Pears
Web Starter Kit Boilerplate & Tooling for Multi-Device Development
HTML Polyfill:
html5shiv
Transpiling:
HAML
jade
Markdown
References:
Element attributes
Elements
HTML Arrows
HTML Entity Lookup
HTML Interfaces Browser Support
HTMLelement.info
Linting/Hinting:
html5-lint
HTMLHint
html-inspector
Optimizer:
HTML Minifier
98
HTML Tools
tablesgenerator.com
Authoring Conventions:
Workflow:
Emmet
https://github.com/trending?l=html&since=monthly
99
CSS Tools
CSS Tools
Desktop & Mobile CSS Frameworks:
Base
Bootstrap
Concise
Foundation
Material Design Lite (MDL)
Materialize
Metro UI
Pure.css
Semantic UI
Ratchet
CSS Reset:
A CSS Reset (or Reset CSS) is a short, often compressed (minified) set of CSS rules
that resets the styling of all HTML elements to a consistent baseline.
cssreset.com
Transpiling:
pleeease.io
PostCSS & cssnext
rework & myth
Sass/SCSS
Stylus
References:
css3test.com
css3clickchart.com
css4-selectors.com
CSS TRIGGERS...A GAME OF LAYOUT, PAINT, AND COMPOSITE
100
CSS Tools
cssvalues.com
MDN CSS Reference
OverAPI CSS cheatsheet
Linting/Hinting:
CSS Lint
stylelint
Code Formatter/Beautifier:
CSScomb
CSSfmt
Optimizer:
clear-css
cssnano
CSSO
Architecting CSS:
Authoring Conventions:
101
CSS Tools
https://github.com/trending?l=css&since=monthly
102
DOM Tools
DOM Tools
DOM Libraries/Frameworks:
clipboard.js
jQuery
Keypress
Tether
Zepto
DOM Monster
References:
Events
DOM Browser Support
DOM Events Browser Support
HTML Interfaces Browser Support
MDN Document Object Model (DOM)
DOM Polyfills/Shims:
dom-shims
Pointer Events Polyfill: a unified event system for the web platform
Virtual DOM:
jsdom
virtual-dom
103
JavaScript Tools
JavaScript Tools
JS Utilities:
accounting.js
async
Chance
format.js
is.js
lodash
Math.js
Moment.js
Numeral.js
string.js
underscore.js
wait
xregexp.com
Babel
jscc.info/
Linting/Hinting:
eshint
jshint
JSLint
jslinterrors.com
Unit Testing:
Jasmine
Jest
Mocha
QUnit
104
JavaScript Tools
Chai
expect.js
should.js
sinon.js
JSCS
Code Formater/Beautifier:
esformatter
js-beautify
jsfmt
Performance Testing:
benchmark.js
jsperf
Blanket.js
Coveralls [$]
escomplex
Esprima
jscomplexity.org
istanbul
Plato
Optimizer:
UglifyJS 2
Obfuscate:
es6fiddle.net
jsbin.com [free to $]
105
JavaScript Tools
jsfiddle.net
debuggex
regex101
regexper
RegExr
Authoring Conventions:
https://github.com/trending?l=javascript&since=monthly
https://www.npmjs.com/browse/depended
106
Static Site Generators Tools
Harp
Metalsmith
Hexo
HubPress
staticgen.com
staticsitegenerators.net
107
App (Desktop, Mobile, Tablet, etc.) Tools
Hoodie
MEAN (i.e., MongoDB, Express, AngularJS, and Node.js.)
Meteor
These solutions can be used anywhere including in a WebView (i.e., web platform and
browser engine) app:
Framework7
Kendo UI Mobile
Mobile Angular UI
Ratchet
ionic
onsen.io
108
App (Desktop, Mobile, Tablet, etc.) Tools
AppBuilder [$]
cocoon.io [free to $]
ionic hub [free to $]
kony [$]
manifoldJS
Monaca [$]
Taco
Electron
NW.js
These solutions use a JS engine at runtime to interpret JS and bridge that to native APIs. No
browser engine or WebView is used. The UI is constructed from native UI components.
NativeScript
React Native
tabris.js [free to $]
trigger.io [$]
References:
todomvc.com
Frontend Guidelines Questionnaire
App Seeds/Starters/Boilerplates:
109
Scaffolding Tools
Scaffolding Tools
Client side Scaffolding is concerned with generating a starter template for the application as
a whole, rather than generating code to access a database.
Slush
Yeoman
110
Templating Tools
Templating Tools
Just Templating:
doT.js
Handlebars
htmlbars
Hogan.js
Mustache.js
Nunjuncks
Transparency
jquerymy.js
knockout
paperclip.js
ractive.js
react.js
riot
Rivets.js
RxJS
vue.js
JSX
t7
111
UI Widgets & Components Tools
Bootstrap
Kendo UI [free to $]
Material ui
Materialize
Metro UI
Office UI Fabric
Polymer Paper Elements
Semantic UI
Webix [$]
Photon
React UI Components for OS X El Capitan and Windows 10
Mobile Focused:
Framework7
Kendo UI Mobile
Mobile Angular UI
Ratchet
112
Data Visualization (e.g., Charts) Tools
d3
sigmajs
amCharts [$]
C3.js
Chartist-jsj
Chart.js
Epoch
FusionCharts [$]
Google Charts
Highcharts [Non-commercial free to $]
ZingChart [free to $]
Services:
ChartBlocks [free to $]
Datawrapper
infogr.am [free to $]
plotly [free to $]
113
Graphics (e.g., SVG, canvas, webgl) Tools
Fabric.js
Two.js
Canvas:
EaselJS
Paper.js
SVG:
d3
Raphal
Snap.svg
svg.js
WebGL:
pixi.js
three.js
114
Animation Tools
Animation Tools
Dynamics.js
GreenSock-JS
snabbt.js
TweenJS
Velocity.js
Polyfills/Shims:
web-animations-js
115
JSON Tools
JSON Tools
Online Editors:
JSONmate
Query Tools:
DefiantJS
JSON Mask
ObjectPath
JSON Generator
Mockaroo
FillText.com
JSONPlaceholder
mockable.io
Mocky
json-server
JSON Specifications/Schemas:
116
Testing Framework Tools
117
Data Storage Tools
118
Module/Package Loading Tools
119
Module/Package Repo. Tools
120
Web/Cloud/Static Hosting Tools
121
Project Management & Code Hosting
122
Collaboration & Communication Tools
Gitter [free to $]
123
CMS Hosted/API Tools
Contentful [$]
Cosmic JS [free to $]
prismic.io [free to $]
webhook.com
124
BAAS (for Front-End Devs) Tools
Back& [free to $]
Firebase [free to $]
Kinvey [free'ish to $]
Pusher [free to $]
Auth0 [$]
Hull [$]
UserApp [free to $]
125
Offline Tools
Offline Tools
Hoodie
Offline.js
PouchDB
upup
126
Security Tools
Security Tools
Coding Tool:
DOMPurify
XSS
References:
127
Tasking (aka Build) Tools
Grunt
Gulp
Brunch
Mimosa
128
Deployment Tools
Deployment Tools
Bamboo [$]
Codeship [free to $]
FTPLOY [free to $]
Travis CI [free to $]
Springloops [free to $]
Surge
Sync Ninja
129
Site/App Monitoring Tools
Pingdom [free to $]
Uptime Robot
Uptrends [$]
General:
New Relic
130
JS Error Monitoring Tools
131
Performance Tools
Performance Tools
Reporting:
JS Tools:
imagemin
ImageOptim-CLI
Budgeting:
performancebudget.io
References/Docs:
Jank Free
Performance of ES6 features relative to the ES5
132