Leanpub Header

Skip to main content

Vue.js Component Patterns

Learn how to level up with Vue.js components.

This book is a quick and fun read that will teach you advanced component patterns with Vue.js!

Free With Membership

With Membership

Free!

$7.99

You pay

$0.00

Author earns

$0.00

Packages

Details
$

...Or Buy With Credits!

You can get credits monthly with a Reader Membership
PDF
EPUB
WEB
483
Readers
About

About

About the Book

What you'll learn

The goal of this course is to teach you the fundamentals to make Vue.js components that are simpler, more flexible and most of all fun to build and use!

This course is the fastest way to get up to speed with advanced Vue.js concepts and is guarantueed to jump start your learning.

Who is this course for?

This course is for everyone with a basic understanding of Vue.js who wants to learn more about using components effectively.

Why you should learn more about components

Having build frontends in multiple frameworks, I'm fascinated by how all these frameworks converge on the very same idea of a reusable component.

And it really is a repeating pattern. You have a component which encapsulates state, logic and even styling. With props in and events out, you can use these components to compose complex UIs.

It is therefore well worth to invest more time in learning how to work with components effectively

What you'll learn

The full course is currently 12 chapters long with more content added constantly.

  • Fundamentals of building portable components with Vue.js
  • How to solve every day problems with Component Composition using Vue.js slots and scoped slots
  • Create Headless or Renderless components for maximum flexibility
  • Build Functional components in cases where a template is not flexible enough
  • Dynamic Component Rendering instead of lots of if/else statements
  • How to use Mixins, Extends, High Order Components and why you should favor composition
  • Refactor large and complex components into Smart vs. Dumb Components
  • You learn about the Prop Drilling Problem and some easy ways to fix it
  • How to use the Provide/Inject Pattern to build composite components
  • Async component loading to improve your apps loading time
  • How to build well behaving components
  • Component Antipatterns - what not to do

Exercises with Solutions

Apply what you learn with more than 12 interesting and real-life exercises with solutions.

Some components you will build:

  • Flexible Card Components
  • Twitter Stream
  • Filtered Lists
  • Countdown Timer
  • Data Provider
  • Themeable Components

The Community

Join the discussion in our Community at spectrum.chat. Show your solutions, give feedback and have fun!

Work in Progress

The Vue.js Component Patterns course is still in production and the price increases as more lessons become available. Get the course today and save a bunch on our Early Access Offer.

Share this book

Packages

Pick Your Package

All packages include the ebook in the following formats: PDF, EPUB, and Web

The Book + Exercises and Solutions

Minimum price

Suggested price$0.00

Improve your understanding with a set of exercises and solutions

Free!

  • Exercises and Solutions
    Exercises and Solutions for each chapter - Apply what you learned!

The Book

Minimum price

Suggested price$14.99

$9.99

    Author

    About the Author

    Frederik Dietz

    My name is Frederik Dietz and I'm a passionate software developer, located in beautiful Hamburg, Germany.

    I am a company founder and freelancer with a focus on React, Vue.js, Elixir, Phoenix Framework and Ruby on Rails.

    I very much enjoy learning and teaching about software development.

    fdietz.de

    Contents

    Table of Contents

    Welcome

    1. Tooling and Code Examples
    2. Structure
    3. Images used in this book

    Introduction to Components with Vue.js

    1. Components can be reused
    2. Passing data to child components as props
    3. Sending messages to parents with events
    4. Summary

    Component Composition with Slots

    1. Slots as Content Placeholders
    2. Named Slots
    3. Summary

    Component Composition with Scoped Slots

    1. List of Items Example
    2. Refactor to Reusable List component
    3. Extending the rendering of the list item
    4. Using Destructuring for scoped slots
    5. Summary

    Headless Components

    1. The Toggle Component
    2. Reusing the component together with a Switch Component
    3. Expand/Collapse Component and Prop Collections
    4. Summary

    Functional components

    1. Functional components using the vue-cli and SFC
    2. Functional components using Vue.component and render function
    3. Functional components using Vue.component and JSX
    4. Summary

    Dynamic component rendering

    1. Using the <component is> feature
    2. Summary

    Mixins, extending components and High Order Components

    1. Global Mixins
    2. Local Mixins
    3. Extending components
    4. High Order Components
    5. Summary

    Smart vs Dumb Components

    1. List of Users as smart and dump components
    2. Summary

    The Prop Drilling Problem

    1. Example with nested components
    2. Solution using slots
    3. Summary

    Provide/Inject

    1. Summary

    Async Components

    1. Summary

    Compound Components

    1. Tabbed Navigation using $children
    2. Accordion using Provide/Inject
    3. Summary

    Data Loader Components

    1. The axios HTTP client library
    2. HTTP Request Component
    3. Summary

    Well behaving Vue components

    1. Implement v-model compatibility
    2. Use events instead of callbacks
    3. Transparent event handling
    4. Attribute handling
    5. Summary

    Component Design Best Practices

    1. Avoid speculative generality
    2. Simple API
    3. Do your research first
    4. Break up components into smaller pieces
    5. Follow the shape of your data
    6. Use composition patterns only when needed
    7. Accessibility
    8. Easy styling
    9. Testing
    10. Documentation
    11. Summary

    Get the free sample chapters

    Click the buttons to get the free sample in PDF or EPUB, or read the sample online here

    The Leanpub 60 Day 100% Happiness Guarantee

    Within 60 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.

    Now, this is technically risky for us, since you'll have the book or course files either way. But we're so confident in our products and services, and in our authors and readers, that we're happy to offer a full money back guarantee for everything we sell.

    You can only find out how good something is by trying it, and because of our 100% money back guarantee there's literally no risk to do so!

    So, there's no reason not to click the Add to Cart button, is there?

    See full terms...

    Earn $8 on a $10 Purchase, and $16 on a $20 Purchase

    We pay 80% royalties on purchases of $7.99 or more, and 80% royalties minus a 50 cent flat fee on purchases between $0.99 and $7.98. You earn $8 on a $10 sale, and $16 on a $20 sale. So, if we sell 5000 non-refunded copies of your book for $20, you'll earn $80,000.

    (Yes, some authors have already earned much more than that on Leanpub.)

    In fact, authors have earned over $14 million writing, publishing and selling on Leanpub.

    Learn more about writing on Leanpub

    Free Updates. DRM Free.

    If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).

    Most Leanpub books are available in PDF (for computers) and EPUB (for phones, tablets and Kindle). The formats that a book includes are shown at the top right corner of this page.

    Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.

    Learn more about Leanpub's ebook formats and where to read them

    Write and Publish on Leanpub

    You can use Leanpub to easily write, publish and sell in-progress and completed ebooks and online courses!

    Leanpub is a powerful platform for serious authors, combining a simple, elegant writing and publishing workflow with a store focused on selling in-progress ebooks.

    Leanpub is a magical typewriter for authors: just write in plain text, and to publish your ebook, just click a button. (Or, if you are producing your ebook your own way, you can even upload your own PDF and/or EPUB files and then publish with one click!) It really is that easy.

    Learn more about writing on Leanpub