Skip to content

fihry/mini-framework

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

90 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Mini-framework-z01

Mini Framework Version License

A lightweight, powerful JavaScript framework for building modern web applications with minimal overhead.


Features

  • 🚀 Virtual DOM — Efficient virtual DOM creation and rendering
  • 🔄 Reactive State Management — Observable state with subscription-based updates
  • 🗺️ Client-side Routing — SPA navigation with route handlers and history management
  • 📡 Event System — Publish/subscribe event architecture
  • Performance Focused — Minimal DOM operations for fast rendering
  • 🧩 Component-Based — Build reusable UI components

Documentation

Installation

CDN

<script src="https://cdn.jsdelivr.net/npm/mini-framework-z01@1.0.7/dist/mini-framework-z01.min.js"></script>

Quick Start

import { createElement, render } from 'https://cdn.jsdelivr.net/npm/mini-framework-z01@1.0.7/dist/mini-framework-z01.min.js';

const app = createElement('div', { id: 'app' }, [
  createElement('h1', {}, ['Hello, World!']),
]);

render(app, document.body);

Core Concepts

Virtual DOM & Rendering

Create virtual DOM nodes and render them to the real DOM:

const element = createElement('div', { class: 'container' }, [
  createElement('p', {}, 'Hello World'),
]);

render(element, document.getElementById('app'));
Note: This framework does not provide an incremental update/diff method. Instead, you re-render the entire virtual DOM tree when your app state changes. The framework handles efficient DOM replacement behind the scenes.

State Management

The createStore provides a simple, observable state object:

const state = createStore({ count: 0 });

// Subscribe to changes
state.subscribe(newState => {
  console.log('State updated:', newState);
  render(app(),container);
});

// Update state triggers subscribers
state.setState({ count: state.getState().count + 1 });

This lets you keep your UI in sync by re-rendering your app on every state change.

Routing

Use the built-in router for SPA navigation:

const router = createRouter();

router.addRoute('/', () => renderHome());
router.addRoute('/about', () => renderAbout());
router.init();

// Navigate programmatically
router.navigate('/about');

Event System

Communicate between components using events:

events.on('user:login', user => {
  console.log('User logged in:', user);
});

events.emit('user:login', { id: 1, name: 'Jane' });

events.off('user:login', handler);

Example Usage

you can find a simple Todo app example in the examples folder.

Authors

Contributing

  • Fork the repository
  • Create a feature branch (git checkout -b feature/my-feature)
  • Commit your changes (git commit -am 'Add some feature')
  • Push to your branch (git push origin feature/my-feature)
  • Create a pull request

License

This project is licensed under the MIT License.

About

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •