Let's Nuxt your landing pages
Maya Shavin
@mayashavin
@mayashavin
- The core of a landing pages
- Why Nuxt?
- Build landing pages with Nuxt & TailwindCSS
- Summary
Agenda
Static landing pages
@mayashavin
@mayashavin
data:image/s3,"s3://crabby-images/d4647/d46470a47c5914a5130d3fd9754619d111f71209" alt=""
data:image/s3,"s3://crabby-images/d4647/d46470a47c5914a5130d3fd9754619d111f71209" alt=""
- HTML/CSS
- Static content
- Minimum run-time JavaScript (or none)
@mayashavin
Why Nuxt?
SSR
Static site generator (SSG)
Single page app (SPA)
Single code base
Build
@mayashavin
@mayashavin
Smarter build process
deploy
static site
templates
contents
nuxt generate
static HTMLs
payload file for extra client API calls
deploy
static site
@mayashavin
Faster deployments
templates
contents
generate
build
static site
first deploy (or code changes)
contents
next deploy (only contents changed)
cached builds
@mayashavin
Optimize performance
🔥 Performant with Vue 3 composition API
🔥 Smaller generated HTML files size
🔥 NO external client-side data API calls
🔥 Faster building time with Vitejs
🔥 Faster app
🔥 TypeScript support
@mayashavin
@mayashavin
Using vanilla approach
Using Nuxt
- NO code-reusability
- NOT easy to maintain
- Readability?
- Handling content (localization?)
- CSS handling
- Vue 3 reusable component
- SSR render (same html output)
- Organized modular structure
- SEO & TailwindCSS modules
- Smart crawling
- Content separation
@mayashavin
Building landing pages
with Nuxt & TailwindCSS
@mayashavin
data:image/s3,"s3://crabby-images/720fc/720fcf6336c91333f4531f95860dd3d10517d69d" alt=""
@mayashavin
Our goals
- Set up Nuxt 3 project
- Add TailwindCSS
- Break down a landing page into components
- Implement page components
- Inject the static data content
- View and deploy
@mayashavin
npx nuxi init <your-landing-page-project>
yarn add -D tailwindcss postcss @tailwindcss/typography autoprefixer
yarn
/*nuxt.config.ts*/
export default defineNuxtConfig({
postcss: {
plugins: {
tailwindcss: {},
autoprefixer: {},
},
}
})
npx tailwindcss init
@mayashavin
/* ./static/main.css */
@tailwind base;
@tailwind components;
@tailwind utilities;
/* app.vue */
<script setup>
import './static/main.css'
</script>
<template>
<NuxtPage/>
</template>
@mayashavin
data:image/s3,"s3://crabby-images/7cdea/7cdeaebb71e24a74ab0365384a87dcf6722fdd36" alt=""
@mayashavin
data:image/s3,"s3://crabby-images/c6118/c611809824366fa137e4512da2f038eb21b63441" alt=""
@mayashavin
Our goals
- Set up Nuxt 3 project
- Add TailwindCSS
- Break down a landing page into components
- Implement page components
- Inject the static data content
- View and deploy
@mayashavin
Summary
- Break down design into components
- Building components with Vue 3
- Styling components with TailwindCSS
- Inject content
- Have a working landing page!
@mayashavin
A LITTLE BIT about me
Senior Software Engineer
MICROSOFT
Core Team
STOREFRONT-UI
Organizer
VUEJS ISRAEL
Blogger & Book Author
@mayashavin
mayashavin.com
data:image/s3,"s3://crabby-images/0d697/0d697fb310b3cb8b66eb50f7a3a76c16ab3ae058" alt=""
data:image/s3,"s3://crabby-images/ea66f/ea66fda8a44c3e610184b534a82bd4a10de8f059" alt=""
data:image/s3,"s3://crabby-images/090a1/090a134478e9f987b9dc53441faf76054e12e709" alt=""
@mayashavin
THANK YOU!
data:image/s3,"s3://crabby-images/8a490/8a49026d5f5677949dabbc90095a22ef5017239c" alt=""
@mayashavin
mayashavin.com
data:image/s3,"s3://crabby-images/8d136/8d136e31b0198665f1e8855fbfecbade5d95cfe3" alt=""
A LITTLE BIT about me
Senior Software Engineer
MICROSOFT
Core Team
STOREFRONT-UI
Organizer
VUEJS ISRAEL
Blogger & Book Author
@mayashavin
mayashavin.com
data:image/s3,"s3://crabby-images/0d697/0d697fb310b3cb8b66eb50f7a3a76c16ab3ae058" alt=""
data:image/s3,"s3://crabby-images/bf6f1/bf6f13fb5fd8015fdf795a3f7cf12563552a701e" alt=""
data:image/s3,"s3://crabby-images/ea66f/ea66fda8a44c3e610184b534a82bd4a10de8f059" alt=""
Thank you
data:image/s3,"s3://crabby-images/8a490/8a49026d5f5677949dabbc90095a22ef5017239c" alt=""
@mayashavin
mayashavin.com
Build landing pages with Nuxt 3 and Tailwind
By Maya Shavin
Build landing pages with Nuxt 3 and Tailwind
- 794