Partial.js is a lightweight JavaScript library designed to simplify handling partial updates and event-driven interactions in web applications. It provides a declarative approach to dynamic content rendering, state management, and AJAX requests, along with support for Server-Sent Events (SSE).
- Declarative Attribute-Based API: Define behaviors directly in HTML using custom attributes like x-get, x-post, x-target, and more.
- Server-Sent Events (SSE): Seamlessly handle real-time updates.
- Infinite Scroll: Built-in support for infinite scrolling functionality.
- Customizable Hooks and Middleware: Add pre- and post-action hooks and middleware for request handling.
- Content Swapping Options: Flexible swapping mechanisms such as outerHTML and innerHTML.
- Automatic Event Handling: Automatically scans and initializes elements with Partial.js attributes.
- Error Handling: Customizable error handling with user-defined callbacks.
<script src="https://cdn.jsdelivr.net/gh/partial-coffee/partial-js/src/partial.js"></script>Add the library to your project and use custom attributes to define dynamic behavior:
<div id="content" x-get="/api/content" x-target="#content">Load Content</div>
<script>
  const partial = new Partial();
</script><div x-sse="/api/stream">Listening for updates...</div>
<script>
  const partial = new Partial();
</script><div x-infinite-scroll x-get="/api/items" x-target="#items">
  <div id="items">Initial content</div>
</div>
<script>
  const partial = new Partial();
</script>When initializing a Partial instance, you can pass an options object to customize behavior:
const partial = new Partial({
  defaultSwapOption: 'innerHTML', // Default content swap method
  onError: (error) => console.error(error), // Error handling callback
  csrfToken: () => document.querySelector('meta[name="csrf-token"]').getAttribute('content'),
  autoFocus: true, // Automatically focus on updated elements
  debounceTime: 300, // Debounce time for event handlers
});- x-get: Perform a GET request.
- x-post: Perform a POST request.
- x-put: Perform a PUT request.
- x-delete: Perform a DELETE request.
- x-patch: Perform a PATCH request.
- x-target: CSS selector of the element to update.
- x-trigger: Event to trigger the action (e.g., click, submit).
- x-debounce: Debounce time in milliseconds.
- x-swap: Content swap method (outerHTML or innerHTML).
- x-sse: URL for Server-Sent Events.
- x-infinite-scroll: Enable infinite scroll.
- x-params: JSON string of additional parameters.
- x-indicator: Selector for a loading indicator element.
- x-confirm: Confirmation message before performing the action.
- x-loading-class: Class to apply during loading.
- x-retry: Number of retries for failed requests.
Hooks allow you to execute custom code at various stages of an action.
partial.addHook('beforeRequest', (context) => {
  console.log('Before request:', context);
});
partial.addHook('afterResponse', (context) => {
  console.log('After response:', context);
});Available hooks:
- onAction
- beforeRequest
- afterResponse
- afterSettle
- beforeSettle
Middleware can be added to modify or augment requests:
partial.use(async (requestParams, next) => {
  console.log('Middleware:', requestParams);
  return await next();
});Custom error handling can be implemented via the onError callback:
const partial = new Partial({
  onError: (error, element) => {
    console.error('Error:', error);
    element.innerHTML = `<div class="error">${error.message}</div>`;
  },
});new Partial(options: PartialOptions);| Option | Type | Description | 
|---|---|---|
| defaultSwapOption | string | Default content swap method (outerHTML or innerHTML). | 
| onError | Function | Error handling callback. | 
| csrfToken | Function | Function to retrieve the CSRF token. | 
| autoFocus | boolean | Automatically focus on updated elements. | 
| debounceTime | number | Debounce time for event handlers. | 
Registers a hook.
Adds middleware.
Dispatches a custom event.
Rescans a container for Partial.js elements.
This project is licensed under the MIT License.
For more details, visit the GitHub repository.