VNDB fork of mithril.js
Find a file
Pat Cavit fa34941cee Starting on a migration guide
I'm sure there's other pieces I'm forgetting
2016-05-25 10:27:28 -07:00
api more tests 2016-05-24 23:16:43 -04:00
bundler clean up index.js 2016-05-21 00:48:58 -04:00
docs Starting on a migration guide 2016-05-25 10:27:28 -07:00
examples Add mithril bundle version of dbmonster 2016-05-19 13:24:28 -07:00
module Quiet some ESLint errors (#1060) 2016-05-19 22:18:31 -07:00
ospec increase timeout threshold because 20 is too close to frame budget @ 60fps 2016-05-19 01:21:07 -04:00
querystring test empty object 2016-05-24 23:18:11 -04:00
render more tests 2016-05-24 23:16:43 -04:00
request more tests 2016-05-24 23:16:43 -04:00
router more tests 2016-05-24 23:16:43 -04:00
test-utils more tests 2016-05-24 23:16:43 -04:00
util more tests 2016-05-24 23:16:43 -04:00
.eslintignore Add ESLint and a generated config/ignore file 2016-05-19 12:37:33 -07:00
.eslintrc.js Linebreaks are hard, spacing isn't (#1062) 2016-05-20 11:51:30 -07:00
.gitignore Quiet some ESLint errors (#1060) 2016-05-19 22:18:31 -07:00
.travis.yml setup CI 2016-04-21 10:19:04 -04:00
CONTRIBUTING.md components, angular dbmon 2016-05-03 23:39:01 -04:00
index.js prop and withAttr work in progress 2016-05-21 01:48:11 -04:00
mithril.js prop and withAttr work in progress 2016-05-21 01:48:11 -04:00
package.json Merge remote-tracking branch 'origin/rewrite' into rewrite 2016-05-19 23:25:20 -04:00
README.md bundler variable disambiguation 2016-05-20 22:38:10 -04:00

Mithril.js - A framework for building brilliant applications

Note: This branch is a sneak peek for the upcoming version 1.0. It's a rewrite from the ground up and it's not backwards compatible with Mithril 0.2.x

This rewrite aims to fix longstanding API design issues, significantly improve performance, and clean up the codebase.

Early Preview

You can install this via NPN using this command:

npm install lhorie/mithril.js#rewrite

Status

Code still is in flux. Most notably, there's no promise polyfill yet and there are several use cases that still need to be polished. DO NOT USE IN PRODUCTION YET!

Some examples of usage can be found in the examples folder. ThreadItJS has the largest API surface coverage and comments indicating pending issues in framework usability. Note that the APIs those examples use may not become the final public API points in v1.0.

Performance

Mithril's virtual DOM engine is less than 500 lines of well organized code and it implements a modern search space reduction diff algorithm and a DOM recycling mechanism, which translate to top-of-class performance. See the dbmon implementation (non-optimized) (for comparison, here are optimized dbmon implementations for React v15.0.2, Angular v2.0.0-beta.17 and Mithril 0.2.x).

Lifecycle methods and Animation Support

Mithril's config method is now replaced by several lifecycle methods to improve separation of concerns and allow better control over animations.

  • oninit(vnode) Runs once before vnode diff and creation
  • oncreate(vnode) Runs once after the DOM element is created. It's guaranteed to run after all DOM changes in the render cycle
  • onupdate(vnode) Runs after vnode is diffed by a re-render. It's guaranteed to run after all DOM changes in the render cycle
  • onbeforeremove(vnode, done) Runs before DOM removal and waits for done to be called before actually removing the DOM element. Affects when onremove is called
  • onremove(vnode) Runs after DOM removal.

Robustness

There are over 2200 assertions in the test suite, and tests cover even difficult-to-test things like location.href, element.innerHTML and XMLHttpRequest usage.

Modularity

Despite the huge performance improvements, the new codebase is smaller than v0.2.x, currently clocking at 5.6kb min+gzip

In addition, Mithril is now completely modular: you can import only the modules that you need and easily integrate 3rd party modules if you wish to use a different library for routing, ajax, and even rendering