This newsletter was sent out to my list on September 15, 2021. Sign up here to get emails like this each week!
Heyo,
Nuxt Nation is happening today (maybe right now depending on when you open this email).
You might still be able to catch some of the action: Nuxt Nation
In the meantime, here are some more tips for ya.
— Michael
🔥 6 Levels of Reusability
My course on reusable components covers this framework, which outlines six different levels of reusability that you can use in your components.
Here are the six levels of reusability:
- Templating — Reusing code by wrapping it up inside of a component
- Configuration — Using configuration props to allow for varying behaviour
- Adaptability — Allowing components to become future-proof
- Inversion — Letting other components control the process
- Extension — Using reusability throughout our component
- Nesting — Creating powerful hierarchies of components
I cover this in more detail in this excerpt from the course
🔥 Grid Template Areas
Sometimes complicated layouts are, well, complicated. But using grid-template-areas
is here to help!
<section>
<header>Page header</header>
<nav>Nav bar</nav>
<main>Content goes here!</main>
<footer>Not for your feet</footer>
</section>
With this HTML, you'd first attach grid-area
names to each element:
header { grid-area: header; }
nav { grid-area: nav; }
main { grid-area: main; }
footer { grid-area: footer; }
Now you can describe your layout:
section {
/* ... some other CSS grid set up here */
grid-template-areas: "header header"
"nav main"
"footer footer";
}
And if you need a single column layout for mobile (with the nav at the bottom, just for fun):
section {
grid-template-areas: "header"
"main"
"nav"
"footer";
}
It's pretty easy to see exactly how the page is being laid out with grid-template-areas
.
đź“ś Helpful Patterns in Vue
Although I disagree with using custom elements to get a flatter component hierarchy, Brennan has a bunch of useful tips and patterns in this article.
I use the loading state one all the time.
Read it here: Helpful Patterns I Use in Vue
đź—ž News: Nuxt Nation is TODAY
We also have three more conferences coming up in the next 2 months, all accessible online and two offering (limited) in-person experiences:
- Vuejs Global (Amsterdam) — October 1st and 4th — Amsterdam and online
- Vue.js Conference (London) — October 20-21 — London and online
- VueConf Toronto — November 22-23 — free + online
đź’¬ Two Types of Languages
"There are only two kinds of languages: the ones people complain about and the ones nobody uses." — Bjarne Stroustrup
🧠Spaced-repetition: Vue Testing Library
The best way to commit something to long-term memory is to periodically review it, gradually increasing the time between reviews 👨‍🔬
Actually remembering these tips is much more useful than just a quick distraction, so here's a tip from a couple weeks ago to jog your memory.
One of my favourite tools for testing is Vue Testing Library:
test('displays correct text', () => {
const { getByText } = render(MyComponent);
getByText(/Fail the test if this text doesn't exist/);
})
It builds on top of vue-test-utils
, making it easier to write tests that are closer to how users actually interact with your app.
Users look for specific text, or look for a button to click. They don't look for the nth child of a div with the class .booking-card-container
.
Writing tests this way makes them easier to understand, simpler to write, and more robust against changes to your code. Nothing about this test is concerned with the implementation, so it's unlikely to break even under a heavy refactor.
If this idea is new to you, I highly encourage you to read more about the Testing Library guiding principles.
Exclusive tips and insights every week
Join 8135 other Vue devs and get exclusive tips and insights like these delivered straight to your inbox, every week.
You have great content in your emails. I seriously learn something from every one of them. — Titus Decali
Thanks for another beautiful tip 🙏 — Victor Onuoha
Loving these, and the spaced repetition — Mark Goldstein
Top comments (0)