这是indexloc提供的服务,不要输入任何密码
Skip to content

anthonyshort/deku

Repository files navigation

Deku Circle CI

version js-standard-style npm downloads

Deku is a library for rendering interfaces using pure functions.

Instead of using classes and local state, Deku just uses functions and pushes the responsibility of all state management and side-effects onto tools like Redux. It also aims to support only modern browsers to keep things simple.

It can be used in place of libraries like React and works well with Redux and other libraries in the React ecosystem.

Deku consists of 4 modules packaged together for convenience:

  • element: Creating virtual elements
  • diff: Computing the difference between two virtual elements
  • dom: DOM renderer
  • string: HTML string renderer

Installation

npm install --save deku

We support the latest two versions of each browser. This means we only support IE10+.

Sauce Test Status

Example

import {dom, element} from 'deku'
import {createStore} from 'redux'
import reducer from './reducer'

// Create a Redux store to handle actions and side-effects
let store = createStore(reducer)

// Create a renderer that can turn vnodes into real DOM elements
let render = dom.createRenderer(document.body, store.dispatch)

// Define a state-less component
let MyButton = {
  render: ({ props, children }) {
    return <button class="my-button">{children}</button>
  }
}

// Update the page and add redux state to the context
render(
  <MyButton>Hello World!</MyButton>,
  store.getState()
)

Documentation

You can read the documentation online at Gitbook.

License

The MIT License (MIT) Copyright (c) 2015 Anthony Short

About

Render interfaces using pure functions and virtual DOM

Resources

Contributing

Stars

Watchers

Forks

Packages

No packages published

Contributors 44