Package Exports
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@base-framework/base) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Base Framework
Framework Overview
Our goal with Base is to solve many client-side rendering issues. Base focuses on reusability, scalability, and performance.
Base has a core that supports adding and removing events, custom events, data-tracking, element class and attribute modifying, object and type utils, etc.
The framework is modular and has additional modules to help with ajax, HTML, layouts, data, data-binding, states, dates, routing, components, atoms, etc.
Layouts
Base framework uses components to render an application. Base creates and renders components using native JavaScript. Layouts are scaffolded using JavaScript object literals. Because the layouts are rendered client-side using native JavaScript, the framework does not require a compiling or build process.
Components and Atoms
Components are encapsulated layouts that contain the presentation and functionality. They are reusable and extensible, helping to reduce redundant code through abstract types.
import { Component } from '@base-framework/base';
/**
 * Page
 *
 * This will create a page component.
 *
 * @class Page
 * @extends {Component}
 */
export class Page extends Component
{
    render()
    {
        return {
            class: 'page'
        };
    }
}Components have lifecycle methods for actions during creation, setup, and destruction.
Atoms are the building blocks for reusable layouts, allowing common design patterns and elements to be shared between multiple components and other atoms.
Element Directives
Elements created by Base have access to custom directives, enabling more functionalities than standard HTML elements. These include caching, adding states, binding and watching data, re-rendering contents, declarative routing and switching, array mapping and binding, event listeners, and more.
Data Binding, Watching, and Linking
Base supports "bindables" for creating and using data, supporting both shallow and deep nested data. Bindables can be one-way or two-way bindings.
Types of bindables include:
- Data: A generic object with complex, deep nested data.
- SimpleData: A shallow data object.
- Models: Child of Data, with default attributes and server resource connectivity.
Performance
Components are static by default, rendering only once per instance. They become dynamic when bound to bindable data sources, allowing for content re-rendering, value changes, function calls, and class additions on data change.
Getting Started
To begin using the Base Framework, follow these steps:
- Clone the repository:
git clone https://github.com/yourrepository/base-framework.git- Navigate to the project directory:
cd base-framework- Install dependencies (ensure Node.js is installed):
npm install @base-framework/base- Import the framework into your project:
import { base } from '@base-framework/base';Usage
Basic Component Creation Create a new component:
import { base, Component } from '@base-framework/base';
/**
 * Page
 *
 * This will create a page component.
 *
 * @class Page
 * @extends {Component}
 */
export class Page extends Component
{
    render()
    {
        /**
         *  This will render an empty div and assign a className
         *  of "value".
         */
        return {
            class: this.key
        };
    }
}Use the builder to create a new instance of the component:
import { Builder } from '@base-framework/base';
import { Page } from './components/page.js';
/**
 * This will create a new instance of the Page component.
 */
const page = new Page(
{
    /**
     * Props can be passed to the component and accessed by their key names.
     *
     * You can name the props anything you want, but it is recommended to
     * use camel case and avoid using reserved keywords.
     */
    key: 'value'
});
// The props passed can now be accessed by the component class.Render the component to the DOM:
import { Builder } from '@base-framework/base';
import { Page } from './components/page.js';
/**
 * This will create a new instance of the Page component.
 */
const page = new Page();
// Render the component to the DOM.
const container = document.body;
Builder.render(page, container);Example Project Using Base Framework
Contributing
Contributions to Base Framework are welcome. Follow these steps to contribute:
- Fork the repository.
- Create a new branch for your feature or bug fix.
- Commit your changes with clear, descriptive messages.
- Push your branch and submit a pull request.
- Before contributing, read our CONTRIBUTING.md for coding standards and community guidelines.
License
Base Framework is licensed under the MIT License. See the LICENSE file for details.
Contact
For questions, suggestions, or issues, contact us:
- Email:
- GitHub Issues: github.com/chrisdurfee/base/issues
- Community Chat: Discord coming soon
- Follow us on Social Media: