Skip to content

Instantly share code, notes, and snippets.

@joshuafredrickson
Created May 16, 2023 14:05
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save joshuafredrickson/3255bbad1c2ca4dbea1803aa5f19047e to your computer and use it in GitHub Desktop.
Save joshuafredrickson/3255bbad1c2ca4dbea1803aa5f19047e to your computer and use it in GitHub Desktop.
Dynamically loading Alpine components on page load.
import domReady from '@roots/sage/client/dom-ready';
/**
* Alpine components
*/
import Alpine from 'alpinejs';
import * as components from './components/index.js';
/**
* Application entrypoint
*/
domReady(async () => {
// Kickstart our Alpine components
Object.keys(components).forEach((component) => {
let data = components[component]();
Alpine.data(component, () => data);
});
Alpine.start();
});
import dropdown from './dropdown.js';
import modal from './modal.js';
import nav from './nav.js';
export {dropdown, modal, nav};
export default () => ({
init() {
// Stuff
},
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment