SKILL.md
readonly只读
name
alpine-js
description
Alpine.js development guidelines for lightweight reactive interactions with Tailwind CSS and various backend frameworks.
Alpine.js Development
You are an expert in Alpine.js for building lightweight, reactive web interfaces.
Core Principles
- Write concise, technical responses with accurate Alpine.js examples
- Use Alpine.js for lightweight, declarative interactivity
- Prioritize performance optimization and minimal JavaScript
- Integrate seamlessly with Tailwind CSS and backend frameworks
Alpine.js Fundamentals
Directives
x-data- Define reactive data for a componentx-bind- Bind attributes to expressionsx-on- Attach event listenersx-model- Two-way data binding for inputsx-show/x-if- Conditional renderingx-for- Loop through arraysx-text/x-html- Set text or HTML contentx-ref- Reference DOM elementsx-init- Run code on initialization
Component Pattern
<div x-data="{ open: false, count: 0 }">
<button @click="open = !open">Toggle</button>
<div x-show="open" x-transition>
<p x-text="count"></p>
<button @click="count++">Increment</button>
</div>
</div>
Integration Patterns
With Tailwind CSS
- Use Tailwind for styling, Alpine for behavior
- Combine
x-bind:classwith Tailwind utilities - Use transitions with
x-transitionand Tailwind
With Laravel/Livewire (TALL Stack)
- Use Alpine for client-side interactivity
- Let Livewire handle server communication
- Use
@entanglefor two-way binding with Livewire - Keep components focused and modular
With Ghost CMS
- Use Alpine for dynamic content interactions
- Integrate with Ghost's content API
- Handle data fetching patterns appropriately
Best Practices
Performance
- Keep
x-dataobjects small and focused - Use
x-showoverx-ifwhen possible for better performance - Lazy load heavy components
- Minimize DOM manipulation
Code Organization
- Extract reusable logic into Alpine.data() components
- Use Alpine.store() for shared state
- Keep inline expressions simple; move complex logic to methods
- Use meaningful variable names
Accessibility
- Ensure keyboard navigation works
- Use proper ARIA attributes
- Test with screen readers
- Maintain focus management
Common Patterns
Dropdown Menu
<div x-data="{ open: false }" @click.away="open = false">
<button @click="open = !open">Menu</button>
<div x-show="open" x-transition>
<!-- Menu items -->
</div>
</div>
Form Validation
<form x-data="{ email: '', isValid: false }" @submit.prevent="submit">
<input x-model="email" @input="isValid = validateEmail(email)">
<button :disabled="!isValid">Submit</button>
</form>
You Might Also Like
Related Skills

verify
243K
Use when you want to validate changes before committing, or when you need to check all React contribution requirements.
facebook
test
243K
Use when you need to run tests for React core. Supports source, www, stable, and experimental channels.
facebook
feature-flags
243K
Use when feature flag tests fail, flags need updating, understanding @gate pragmas, debugging channel-specific test failures, or adding new flags to React.
facebook
extract-errors
243K
Use when adding new error messages to React, or seeing "unknown error code" warnings.
facebook