Intro To Front End Build Tools
Preprocessing, Build tools, Version Control, and Content Management Systems
Front-end web development is mainly focused on three core client-side technologies, HTML, CSS and JavaScript. Each plays an important role during the final output/rendering of web sites and web pages. During the web development process, there are many other technologies, build tools, and workflows that are used by front-end web developers to help make the process easier, more manageable, flexible, scalable, more efficient, and more powerful. Many developers set up custom local development environments that include build tools and complex workflows across multiple projects. One of the many challenges faced by front-end developers is how does one keep up with the rapidly changing workflows, tools, technologies, and techniques used in the industry? There are multiple different ways to create the front-end of a website and the best practices are often times debated as new practices emerge and change frequently.
Outcomes:
- Learn how to set up a custom front-end development environment and workflow
Front-end Web Development Related Keywords & Concepts
- Separation of Content and Presentation (Style)
- Scalability & Modularization
- Automation
- Abstraction & Compiling
- Collaboration
Front-end Build Tools & Technologies:
- Version Control systems (e.g. Git, Github)
- Pre-Processors (e.g. SASS)
- Package Managers (e.g. Node.js, npm)
- Task Managers (e.g. Gulp)
- Content Management Systems (e.g. Wordpress)
A Basic Example Workflow:
Using GitHub, GitHub Pages, & Prepros
- Setup a GitHub repo for your project (for version control)
- Setup your repo for GitHub pages (for free static hosting and auto-deployment)
- Clone your repo locally
- Use Prepros to locally create, manage, and build your site using various build tools such as a css pre-processor (SASS for variables, partials, etc.) and any other build tools/plugins desired (e.g. auto image optimization, templating, minifying, etc).
- When finished working locally, commit/push your code to your GitHUb master repo to save, backup, and deploy your site.
A More Advanced Example Workflow:
Using GitHub, NPM, Gulp, & Netlify
- Setup a GitHub repo for your project (for version control)
- Link your GitHub repo to Netlify (for fast static hosting and auto-deployment)
- Clone your repo locally
- Use npm install to setup a local development environment and CLI workflow to create, manage, and build your site using Gulp as a task manager along with various plugins to automate the build process (e.g. compile HAML, SASS, etc., concatenate files, optimize images, minify distribution files, etc).
- When finished working locally, commit/push your code to your GitHub master repo that will trigger a webhook to auto deploy your site to Netlify.
Front-end Related Reading & Resources
- Reading:
- Front-End Developer Handbook 2018
https://frontendmasters.com/books/front-end-handbook/2018/ - How to Keep Up With Front-end Technologies
https://uptodate.frontendrescue.org/
- Front-End Developer Handbook 2018
- Technology-specific Resources:
- Version Control
- Git - https://git-scm.com/
- Github - https://github.com/
- Package Manager
- NPM (Node.js) - https://www.npmjs.com/
- Task Manager
- Prepros (GUI): https://prepros.io/
- Gulp (CLI) - https://gulpjs.com/
- CSS Pre-Processor
- Sass - http://sass-lang.com/
- Content Management Systems (CMS)
- Wordpress - https://wordpress.org/ (not .com)
- Version Control
Lesson-related:
- Demos/examples:
- Sitebase on Github: https://github.com/kccnma/sitebase
- Sitebase WP test install: http://www.egargiulo.com/nma/test07/
- Wordpress-related client examples: